码迷,mamicode.com
首页 > 编程语言 > 详细

堆排序其实没那么难

时间:2019-12-17 13:24:57      阅读:99      评论:0      收藏:0      [点我收藏+]

标签:二叉树   等于   完全二叉树   左右   完成   大于   关注   src   大根堆   

堆指的是每个节点的值大于等于或小于等于左右节点的值的完全二叉树结构,堆又分顶堆(每个节点的值大于等于左右节点的值)和顶堆(每个节点的值小于等于左右节点的值)

技术图片

 

使用堆进行排序的前提是要先构造一个堆出来,这里以大顶堆为例。

给定一个数组进行构造大顶堆。

技术图片

 

构造大顶堆的主要思路:

1、n个数据;

2、从待处理的数据里取出一个数据,插入到堆的尾部,并调整成大顶堆;

    2.1、如果调整的节点值比其父节点值大,那么两个节点交换值,重复该步骤,直到调整的节点是根节点

    2.2、否则插入节点后就是大顶堆,无需调整

3、重复步骤2直到所有数据已取出。

 

构造堆的代码实现:

技术图片

 

堆也构建完了,那么剩下就是该怎么排序了,排序的思路是:

1、有n个元素的大根堆;

2、用根节点和当前堆的最后一个节点进行交换;

3、将剩下的n-1个元素再调整成大顶堆(调整大顶堆思路参照构造大顶堆的思路);

4、重复步骤2、步骤3,直到完成排序。

 

代码实现:

技术图片

 

得到的数组,逆序输出就是排序后的数组了。

关注公众号 吃菜长肉 

堆排序其实没那么难

标签:二叉树   等于   完全二叉树   左右   完成   大于   关注   src   大根堆   

原文地址:https://www.cnblogs.com/chicaizhangrou/p/12053890.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!