对一个数组中的元素按照顺序构建二叉树,就形成了一个(二叉)堆。(二叉树是虚拟的,并不是真的建立二叉树)

表示堆的数组A有两个重要属性:A.heapSize,表示堆里面有多少元素,数组里有多少元素在堆里

           A.length,表示数组长度      

例如数组A= {1,2,3,4,5,6,7,8,9,10},此时A.heapSize = A.length。除了最后一层之外,这个二叉树是完满的

最大堆:父节点的值总是不小于子节点的值,反应在数组中就是A[i]>=A[2i+1] && A[i]>=A[2i+2],如果2i+2<A.size的话

最小堆:父节点的值总是不大于子节点的值,反应在数组中就是A[i]<=A[2i+1] && A[i]<=A[2i+2],如果2i+2<A.size的话,上图就是一个最小堆

堆排一般用最大堆,输出升序数组,最小堆用于优先队列。

堆排的时间复杂度是O(nlgn)

我写的是最小堆排序,输出降序数组

//=================== 最小堆维护 ==================
// 调整根节点为arr[i]的子树顺序,将最小的节点放到根节点位置
// 递归调整被置换的子节点
void minHeapfy(vector<int> &arr, int i, int heapSize){
int left = * i + ; //对于arr[i],它的左孩子是arr[2i+1]右孩子是arr[2i+2]
int right = * i + ;
int least = i; if (left < heapSize && arr[left] < arr[least])
least = left; if (right < heapSize && arr[right] < arr[least]){
least = right;
} if (least != i){
int temp = arr[i];
arr[i] = arr[least];
arr[least] = temp;
minHeapfy(arr, least, heapSize); //如果子树发生变动,递归调整有变动的子节点
}
} //=============== 建立最小堆 ================
// 利用minHeapfy调整每一棵子树,arr中arr[arrSize/2:]的元素都是叶子节点
void buildMinHeap(vector<int> &arr){
int heapSize = arr.size();
for (int i = heapSize/-; i >= ; i--){
minHeapfy(arr, i, heapSize);
}
} // ================ 输出堆排结果 ====================
//由于根节点总是全堆最小的,每次置换根节点与最后一个节点
//对被置换之前的数组进行最小堆建立
void heapSort(vector<int> &arr){
int heapSize = arr.size();
buildMinHeap(arr);
for (int i = heapSize - ; i >= ; i--){
int temp = arr[]; //置换根节点元素和当前数组最后一个元素
arr[] = arr[i];
arr[i] = temp; heapSize -= ;
minHeapfy(arr, , heapSize); //对有序元素之前的节点建立最小堆
}
} int _tmain(int argc, _TCHAR* argv[])
{
vector<int> primes = { , , , , , , , , , }; heapSort(primes);
for (int i = ; i < primes.size(); i++){
cout << primes[i] << endl;
} system("pause");
return ;
}

【Algorithm】堆排,C++实现的更多相关文章

  1. 数组第K小数问题 及其对于 快排和堆排 的相关优化比较

    题目描述 给定一个整数数组a[0,...,n-1],求数组中第k小数 输入描述 首先输入数组长度n和k,其中1<=n<=5000, 1<=k<=n 然后输出n个整形元素,每个数 ...

  2. P1177 【模板】快速排序(学完归并和堆排之后的二更)

    P1177 [模板]快速排序 不用说,连题目上都标了是一道模板,那今天就来对能用到的许多排序方式进行一个总结: 选择排序 选择排序(Selection sort)是一种简单直观的排序算法.它的工作原理 ...

  3. STL_算法_Heap算法(堆排)(精)

    C++ Primer 学习中. . . 简单记录下我的学习过程 (代码为主) /***************************************** STL-算法--Heap算法 堆排序 ...

  4. DS 图解堆排

    堆排其实就是选择排序,只不过用了完全二叉树特性. 堆排思想 : 利用完全二叉树特性建堆和重复选择调整来得到有序数组. 完全二叉树有什么特性呢? 节点左对齐 ---> 层序遍历不会出现空,可以用数 ...

  5. 造轮子-Java泛型堆排

    个人博客地址:http://kyle.org.cn/2018/03/13/heapsort/ Java实现泛型堆排算法,用于N个对象中选择最大或者最小的前M个,其中M<=N 类似于Mysql中o ...

  6. 排序算法C语言实现——冒泡、快排、堆排对比

    对冒泡.快排.堆排这3个算法做了验证,结果分析如下: 一.结果分析 时间消耗:快排 < 堆排 < 冒泡. 空间消耗:冒泡O(1) = 堆排O(1) < 快排O(logn)~O(n) ...

  7. python 快排,堆排,归并

    #归并排序 def mergeSort(a,L,R) :     if(L>=R) :         return     mid=((L+R)>>1)     mergeSort ...

  8. java 堆排,优先级队列,归并排序

    堆排 堆排是基于二叉树而得来的 例如:对一个数组 可以转为二叉树:       二叉树特性父节点为 i ,  左叶子节点为2i+1:右叶子节点为2i+2; 步骤分解: 1. 先从第一个非叶子节点(即下 ...

  9. 堆排Heap Sort

    1. #define LeftChild(i) (2*(i)+1) void PercDown(vector<int>&num, int i, int n) { int child ...

随机推荐

  1. [leetCode][013] Two Sum 2

    题目: Given an array of integers that is already sorted in ascending order, find two numbers such that ...

  2. 【BZOJ】2435: [Noi2011]道路修建(树形dp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2435 我怎么感觉那么水.. 坑的是,dfs会爆...好吧..用bfs.. //upd:我的智商也是醉 ...

  3. 【BZOJ】2329: [HNOI2011]括号修复(splay+特殊的技巧)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2329 和前一题一样,不就多了个replace操作吗.好,就打一下. 然后交上去wa了........ ...

  4. android开发 BaseAdapter中getView()里的3个参数是什么意思

    BaseAdapter适配器里有个getView()需要重写public View getView(int position,View converView,ViewGroup parent){ // ...

  5. Js操作Select大全

    判断select选项中 是否存在Value="paraValue"的Item 向select选项中 加入一个Item 从select选项中 删除一个Item 删除select中选中 ...

  6. itellyou MSDN, 我告诉你 win7系统工具等

    http://www.itellyou.cn/ 操作系统-window7-中文-Windows 7 Ultimate with Service Pack 1 (x64) - DVD (Chinese- ...

  7. debug阶段工作期站立会议2(进度推进)

    组名:天天向上 组长:王森 组员:张政.张金生.林莉.胡丽娜 代码地址:HTTPS:https://git.coding.net/jx8zjs/llk.git SSH:git@git.coding.n ...

  8. Jenkins学习记录

    参考资料 官方文档 用MSBuild和Jenkins搭建持续集成环境(1) 用MSBuild和Jenkins搭建持续集成环境(2) 构建基于Jenkins + Github的持续集成环境 Jenkin ...

  9. 【IOS笔记】Views

    Views Because view objects are the main way your application interacts with the user, they have many ...

  10. RedirectResult,RedirectToRoute

    RedirectResult:运行重新导向到其他网址,在RedirectResult的内部,基本上还是以Response.Redirect方法响应HTTP 302暂时导向. eg: public Ac ...