堆排序其实没那么难

image

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

image

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

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

image

构造大顶堆的主要思路:

1、n个数据;

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

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

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

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

构造堆的代码实现:

image

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

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

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

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

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

代码实现:

image

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

关注公众号「吃菜长肉」,获取更多内容。

推荐阅读:

5分钟搞定快速排序

常见排序算法(1)一一插入排序

你可能感兴趣的:(堆排序其实没那么难)