当前位置: 首页 > news >正文

算法与数据结构(八)--优先队列

普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除,在某些情况下,我们可能需要找出队列中的最大值或者最小值
例如使用一个队列保存计算机的任务,一般情况下计算机的任务都是有优先级的,我们需要在最小计算机的任务中找出优先级最高的任务先执行,执行完毕后就需要吧这个任务从队列中删除。
普通的队列要完成这样的姑娘,需要每次便利队列中的所有元素,比较并找出最大值,效率不是很高,这个时候,我们就需要用一种特殊的队列来完成这种需求:优先队列

优先队列按照作用可分为两类:
最大优先队列:可以获取并删除队列中最大的值
最小优先队列:可以获取并删除队列中最小的值


优先队列是通常是靠堆实现的。

一.最大优先队列

我们之前学习过堆,而堆这种结构是可以方便的删除最大的值,所以我们可以基于堆区实现最大优先队列。

二.最小优先队列

最小优先队列实现起来也比较简单,我们同样也可以基于堆来完成最小优先队列。
我们前面学习堆的时候,堆中存放数据元素的数组要满足如下特性:
1.最大的元素放在数组的索引1处。
2.每个结点的数据总是大于等于它的两个子结点的数据。

其实我们之前实现的队可以把它叫做最大堆,我们可以用相反的思想实现最小堆,让对重存放数组元素的数组满足如下特性:
1.最小的元素放在数组的索引1处。
2.每个结点的数据总是小于等于它的两个子结点的数据。

这样我们就能很快的访问到堆中最小的数据。

http://www.lryc.cn/news/139347.html

相关文章:

  • React 全栈体系(三)
  • 腾讯云下一代CDN -- EdgeOne加速MinIO对象存储
  • GitLab-CI 指南
  • MyBatis的核心技术掌握,简单易懂(上)
  • Redisson自定义序列化
  • MongoDB Long 类型 shell 查询
  • 回归预测 | MATLAB实现GA-APSO-IBP改进遗传-粒子群算法优化双层BP神经网络多输入单输出回归预测
  • Spring cache整合Redis使用介绍
  • Metasploit提权
  • TypeScript三种特殊类型
  • 如何使用CSS实现一个响应式轮播图?
  • 数据生成 | MATLAB实现MCMC马尔科夫蒙特卡洛模拟的数据生成
  • 【从零开始的rust web开发之路 二】axum中间件和共享状态使用
  • Vue操作时间
  • 数据库——Redis 常见数据结构以及使用场景分析
  • 数学建模-规划工具箱yalmip
  • [SQL挖掘机] - 窗口函数 - 计算移动平均
  • 域名和hostname
  • echarts 甘特图一组显示多组数据
  • 1139. 最大的以 1 为边界的正方形;2087. 网格图中机器人回家的最小代价;1145. 二叉树着色游戏
  • css滚动条的使用
  • 优化Python代理爬虫的应用
  • [C++] STL_vector使用与常用接口的模拟实现
  • 【LeetCode】167. 两数之和 II - 输入有序数组 - 双指针
  • YOLOV1
  • 美团增量数仓建设新进展
  • ​LeetCode解法汇总2337. 移动片段得到字符串
  • Fpass与Fstop
  • Java快速入门体验
  • 父组件传给子组件的数据是异步的,为什么会导致子组件比父组件先执行?