堆和优先队列

旧城等待, 2021-09-23 22:30 519阅读 0赞

什么是优先队列

在这里插入图片描述

为什么会使用优先队列

动态:

任务处理中心随时都在处理各种各样的请求,也就是说不是一开始就确定了各种请求的优先级的,请求的优先级是不断地变化的。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

堆的基本结构

堆其实也是一棵树。
在这里插入图片描述

二叉堆的性质 :

首先是一个完全二叉树

堆中某个节点的值总是不大于其父节点的值 ——>最大堆
在这里插入图片描述

数组实现最大堆

  1. package MaxHeap;
  2. public class MaxHeap<E extends Comparable<E>> {
  3. private Array<E> data;
  4. public MaxHeap(int capacity) {
  5. data = new Array<>(capacity);
  6. }
  7. public MaxHeap() {
  8. data = new Array<>();
  9. }
  10. // 返回堆中的元素个数
  11. public int size() {
  12. return data.getSize();
  13. }
  14. // 返回一个布尔值, 表示堆中是否为空
  15. public boolean isEmpty() {
  16. return data.isEmpty();
  17. }
  18. // 返回完全二叉树的数组表示中,一个索引所表示的元素的父亲节点的索引
  19. private int parent(int index) {
  20. if (index == 0)
  21. throw new IllegalArgumentException("index-0 doesn't have parent.");
  22. return (index - 1) / 2;
  23. }
  24. // 返回完全二叉树的数组表示中,一个索引所表示的元素的左孩子节点的索引
  25. private int leftChild(int index) {
  26. return index * 2 + 1;
  27. }
  28. // 返回完全二叉树的数组表示中,一个索引所表示的元素的右孩子节点的索引
  29. private int rightChild(int index) {
  30. return index * 2 + 2;
  31. }
  32. }

发表评论

表情:
评论列表 (有 0 条评论,519人围观)

还没有评论,来说两句吧...

相关阅读

    相关 数据结构之优先队列

    目录 堆和优先队列的应用 堆排序 任务调度 包裹分拣 霍夫曼编码 负载均衡 堆的描述 优先队列的描述 问与答 左平衡二叉树特别适合存储于数组中,为什么这种

    相关 优先队列

    设计一个程序模仿操作系统的进程管理问题,进 程服务按优先级高的先服务,同优先级的先到先服务的管理 原则。设文件task.txt中存放了仿真进程服务请求,其中第 一列是进程任务号