平均时间复杂度:O(nlogn) 最佳时间复杂度:O(nlogn) 最差时间复杂度:O(nlogn) 稳定性:不稳定
堆排序其实也是一种选择排序,是一种树形选择排序。只不过直接选择排序中,为了从R[1...n]中选择最大记录,需比较n-1次,
然后从R[1...n-2]中选择最大记录需比较n-2次。
事实上这n-2次比较中有很多已经在前面的n-1次比较中已经做过,而树形选择排序恰好利用树形的特点保存了部分前面的比较结果,
因此可以减少比较次数。对于n个关键字序列,最坏情况下每个节点需比较log2(n)次,因此其最坏情况下时间复杂度为nlogn。
堆排序为不稳定排序,不适合记录较少的排序。
#include <iostream>
#include <cstdio>
#include <algorithm>//c++11不需要 swap在std命名空间里面
/** 找到当前子树最大结点,放到父节点*/
void heapify(int arr[],int i,int len)
{
if(i < len)
{
int right = 2*i&