二叉堆(优先队列)
2017-05-24 20:47
204 查看
二叉堆概念
由完全二叉树表示代码上完全二叉树可以用数组来存储
0 | 1 | 2 | 3 | 4 | 5 | 6 |
二叉堆性质
根据等比数列求和公式可以得到,n层的完全二叉树的节点数为2^n-1,最后一层的总节点数是之前所有层的节点数之和加一。堆操作
新元素插入堆,堆大小++,新元素可能需要上浮,每次是否上浮只需要跟其父节点进行比较。删除堆顶元素,将其与堆中最后一个元素交换,然后堆大小--,交换后的元素打破了堆的秩序,它需要跟两个子元素进行比较,做出下沉操作。
堆性能
N个元素的堆,插入元素的比较次数最多为logN,删除最大元素的比较次数最多为2logN相关文章推荐
- ZOJ 2724 Windows Message Queue (二叉堆,优先队列)
- POJ2431 二叉堆(优先队列)以及贪心算法
- ZOJ 2724 Windows Message Queue (二叉堆,优先队列)
- 优先队列(二叉堆)模板(template)
- (二叉堆10.2.1)ZOJ 2724 Windows Message Queue(对结构体使用优先队列)
- 二叉堆(优先队列)的基本操作的测试
- 二叉堆_完全二叉树_优先队列
- 《Algorithms算法》笔记:优先队列(2)——二叉堆
- 看图说话之二叉堆(优先队列)——原理解析
- 《常见算法和数据结构》优先队列(2)——二叉堆
- 【数据结构与算法基础】优先队列(二叉堆实现) / Priority Queue implemented by binary heap
- ZOJ 2724 Windows Message Queue(二叉堆||优先队列)
- LeetCode基础-排序-二叉堆排序(优先队列)
- 二叉堆(优先队列)
- 二叉堆(优先队列)
- 优先队列——二叉堆、d堆、左式堆、斜堆
- 二叉堆(优先队列)
- 挑战程序设计竞赛 二叉堆(优先队列)的实现
- BZOJ 1150 二叉堆(优先队列) + 贪心
- 优先队列(利用二叉堆实现)