【数据结构】·优先队列


联系作者:humminwang@163.com

优先队列

优先队列 ( p r i o r i t y   q u e u e ) (priority \ queue) (priority queue)定义:

普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除。在优先队列中,元素被赋予优先级。当访问元素时,具有最高优先级的元素最先删除。优先队列具有最高级先出 ( f i r s t   i n , l a r g e s t   o u t ) (first \ in, largest \ out) first in,largest out的行为特征。
通常采用 数据结构来实现。

简单陈述:

具备优先级的队列,队首元素总为优先级最高的元素,而这个优先级是程序员设定的,比如,拥有最大值的元素优先级最高,那么在每次在向优先队列删除或者添加元素时,队首的元素总是该队列中的最大值。


C++代码实现
#include<queue>
// priority_queue<结构类型> 队列名;
priority_queue <int> i;
priority_queue <int,vector<int>,greater<int> > q;//从小到大
priority_queue <int,vector<int>,less<int> >q;//从大到小


q.size();//返回q里元素个数
q.empty();//返回q是否为空,空则返回1,否则返回0
q.push(k);//在q的末尾插入k
q.pop();//删掉q的第一个元素
q.top();//返回q的第一个元素



//自定义的排序规则
struct node
{
	int fir,sec;
	void Read() {scanf("%d %d",&fir,&sec);}
}input;

struct cmp1
{
	bool operator () (const node &x,const node &y) const
	{
		return x.fir<y.fir;
	}
};//当一个node x的fir值小于另一个node y的fir值时,称x<y

priority_queue<node,vector<node>,cmp1> q1;

下节我们介绍堆,一种实现优先队列的基本数据结构。

Reference:

https://blog.csdn.net/c20182030/article/details/70757660
https://baike.baidu.com/item/%E4%BC%98%E5%85%88%E9%98%9F%E5%88%97/9354754?fr=aladdin

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值