堆排序其实没那么难

Posted chicaizhangrou

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了堆排序其实没那么难相关的知识,希望对你有一定的参考价值。

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

技术图片

 

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

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

技术图片

 

构造大顶堆的主要思路:

1、n个数据;

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

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

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

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

 

构造堆的代码实现:

技术图片

 

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

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

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

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

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

 

代码实现:

技术图片

 

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

关注公众号 吃菜长肉 

以上是关于堆排序其实没那么难的主要内容,如果未能解决你的问题,请参考以下文章

排序算法:堆排序-Java实现

我终于弄懂选择排序(堆排序)

两分钟真能搞懂桶排序

你所知道的十大排序算法的总结(冒泡,选择,插入,希尔,归并,快排,堆排序,计数排序,桶排序,基数排序)

介绍一下PriorityQueue,以及优先队列实现大小根堆

堆结构和堆排序的Java实现