# include <queue>
using namespace std;
priority_queue<typename> name;
只能通过top()函数来访问队首的元素
priority_queue<int> q;
q.push(4);
q.push(3);
q.push(2);
cout<<q.top()<<endl;//4
使得元素x入队,时间复杂度为o(logN)。
获取队首的元素,时间复杂度为o(1)
pop()令队首出队,时间复杂度为o(logN)
检测队列是否为空,返回true,返回false
返回队列中的元素数量
对于基础类型,一般是数字大的优先级高,对于字符,就是字典序越大,优先级越高。
priority_queue<int> q;
priority_queue<int,vector<int>,less<int>>;
两种定义方式等价
例子
struct fruite{
string name;
string price;
};
价格高优先级高
设置友元函数,重载小于号<
struct fruite{
string name;
string price;
friend bool operator <(fruite a,fruite b){
return fruite.price<fruite.price;
}
};
注意
只能重载小于号
如果"重载>"
friend bool operator <(fruite a,fruite b){
return fruite.price>fruite.price;
}
struct fruite{
string name;
string price;
};
struct cmp{
bool operator() (fruite a,fruite b){
return a.price>b.price;
}
};
priority_queue<fruite,vector<fruite>,cmp> q;
原文:https://www.cnblogs.com/mengxiaoleng/p/11387601.html