堆排序基本介绍
1)堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,它的最坏,最好,平均时间复杂度均为O(nlogn),它也是不稳定排序。
2)堆是具有以下性质的完全二叉树:每个结点的值都大于或等于其左右孩子结点的值,称为大顶堆,注意:没有要求结点的左孩子的值和右孩子的值的大小关系。
3)每个结点的值都小于或等于其左右孩子结点的值,称为小顶堆。
大顶堆示意图:
按层进行编号有数组:[50,45,40,20,25,35,30,10,15]
从上图可以得到大顶堆的特点:
arr[i] >= arr[2i+1]&&arr[i]>=arr[i2+2];对应第几个节点,i从0编号
小顶堆示意图
从上图可以得到小顶堆的特点:
arr[i] <= arr[2i+1]&&arr[i]<=arr[i2+2];对应第几个节点,i从0编号
一般升序采用大顶堆,降序采用小顶堆。
堆排序的思路
1)将待排序序列构造成一个大顶堆
2)此时,整个序列的最大值就是堆顶的根节点。
3)将其与末尾元素进行交换,此时末尾就为最大值。
4)然后将剩余n-1个元素重新构造成一个堆,这样会得到n个元素的次小值。如此反复执行,便能得到一个有序序列了。
可以看到在构建大顶堆的过程中,元素的个数逐渐减少,最后就得到一个有序序列了。
动态图
代码实现(大顶堆)
public class HeapSort {
public static void main(String[] args) {
//升序
int arr[] = {