Priority Queue Interface & Implementation
Priority Queue Interface
Priority Queue 在 Queue 的基础上,为 Queue 中的每个元素设置优先级,从而影响 dequeue 的顺序。我们知道 Queue 的 dequeue 是遵循 FIFO 策略,但现实中有很多场景的 dequeue 需要按照一定的优先级实施调度策略:
飞机头等舱与经济舱的登机顺序
操作系统的进程调度管理
...
将这些场景抽象起来,就得到了 Priority Queue Interface:
方法 | 功能 |
| 将元素 x 插入到队列 Q 中 |
| 返回队列 Q 中优先级最高的元素 |
| 将队列 Q 中优先级最高的元素出列,并返回 |
| 将队列 Q 中的元素 x 的优先级变成 k (k 大于当前优先级) |
Implementation
在 Priority Queue 中,元素处于一种 “半排序” 的状态,它需要高效地支持三种操作:
定位优先级最高的元素
优先级最高的元素出列后,定位下一个优先级最高的元素
新的元素入列后处在合理的排序位置
这也是实现好的 Priority Queue 的关键所在。
Binary Heap (以 Max Heap 为例)
方法 | 时间复杂度 | 空间复杂度 |
|
|
|
|
|
|
|
|
|
Binary Heap 有两个不变特性(invariants):
Structure Property: 结构上它是一棵二叉完全数(binary complete tree)
Heap Order Property: 父节点的取值大于它的子节点的取值
实现示例:
binary_heap.py
Python heapq
参考
Last updated