首页 > 其他 > 详细

优先队列

时间:2020-02-10 12:21:42      阅读:79      评论:0      收藏:0      [点我收藏+]

优先队列容器和队列一样,只能从队尾插入元素,从队首删除元素。  

 为什么能叫优先队列呢??因为它有一个特性,就是队列中每个元素都有一个优先级,所以出队时,并不是完全一样的遵循先进先出的原则来进行的,而是将队列中优先级大的出队。这点有点儿类似于给队列里元素先进行一个排序,再按照顺序出队。元素的比较规则默认按照元素值由大到小排序,

1.头文件:

#include<queue>

2.声明方式

priority_queue<int> a; //通过操作,按照元素从大到小的顺序出队
priority_queue<int,vector<int>,greater<int> > b; //通过操作,按照元素从小到大的顺序出队
priority_queue<int,vector<int>,less<int> >c;     //从大到小

另外还可以自定义排序方法,先不写

3.常用操作

  • top 访问队头元素
  • empty 队列是否为空
  • size 返回队列内元素个数
  • push 插入元素到队尾 (并排序)
  • emplace 原地构造一个元素并插入队列
  • pop 弹出队头元素
  • swap 交换内容

优先队列

原文:https://www.cnblogs.com/fate-/p/12290429.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!