堆排序
堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法。堆积是一个近似完全二叉树的结构,并同时满足堆积的性质:即子结点的键值或索引总是小于(或者大于)它的父节点。
基本思想
利用大顶堆(小顶堆)堆顶记录的是最大关键字(最小关键字)这一特性,使得每次从无序中选择最大记录(最小记录)变得简单。
将待排序的序列构造成一个最大堆,此时序列的最大值为根节点 ,依次将根节点与待排序序列的最后一个元素交换,再维护从根节点到该元素的前一个节点为最大堆,如此往复,最终得到一个递增序列
假设给定一个组无序数列
创建最大堆
首先我们将数组我们将数组从上至下按顺序排列,转换成二叉树:一个无序堆。
从最后一个堆开始,即90那个堆开始;首先对比左右孩子,如果右孩子比左孩子的值大,交换左右孩子的值,然后比较左孩子与父节点的值,如果左孩子的值小于父节点的值,不用交换,如果发生交换,要检测子节点是否为其他堆的父节点,如果是,递归进行同样的操作。
然后的到最大堆