priority的pair建立和pair

本文详细介绍了如何在C++中使用priority_queue实现升序和降序队列,包括使用不同比较函数如greater和less,并通过实例展示了不同类型的数据结构(如整数和pair)的应用。同时,讨论了默认排序规则和如何自定义排序。
摘要由CSDN通过智能技术生成

优先队列的
定义:priority_queue<Type, Container, Functional>
注意:当两个或两个以上的尖括号连在一起时中间要加上空格分开不然会认成左移或者右移出现报错

//升序队列
priority_queue <int,vector<int>,greater<int> > q;
//降序队列
priority_queue <int,vector<int>,less<int> > q;
//这里面的升序和降序分别是这样的
int a=1;
int b=2;
int c=3;
priority_queue <int,vector<int>,greater<int> > q;
q.push(b);
q.push(c);
q.push(a);
//这样定义是升序,输出的结果就是
//1 2 3
//相反 less就是
//3 2 1
priority_queue <int> q;
//如果这样定义
//就默认是
priority_queue <int,vector<int>,less<int> > q;

用pair是先比较第一个元素,第一个相等比较第二个元素

//升序队列
priority_queue< pair<int,int> ,vector<pair<int,int> >,greater<pair<int,int> > > q;
//降序队列
priority_queue< pair<int,int> ,vector<pair<int,int> >,less<pair<int,int> > >  q;

pair可以同时定义两个类型相同或不同的元素

pair<数据类型,数据类型>PII;
PII a(1,2);
//a.first就是1
//a.second就是2
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值