admin管理员组文章数量:1623796
目录
1. priority_queue的定义
2. priority_queue容器内元素的访问
3. priority_queue常用函数实例解析
(0)top()
(1)push()与pop()
(2)empty()
(3)size()
4. priority_queue内元素优先级的设置
(1)基本数据类型的优先级设置
(2)结构体的优先级设置
priority_queue又称为优先队列,其底层是用堆来实现的。在优先队列中,队首元素一定是当前队列中优先级最高的那一个。例如在队列有如下元素,且定义好了优先级:
桃子(优先级3)
梨子(优先级4)
苹果(优先级1)
那么出队的顺序为梨子(4)->桃子(3)->苹果(1)。
当然,可以在任何时候向优先队列里加入元素,优先队列底层的数据结构(堆)会随时调整结构,使得每次的队首元素都是优先级最大的。
这里的优先级是人为规定出来的,后面会展示如何自定义优先级。
1. priority_queue的定义
添加头文件#include <queue>,并加上using namespace std;
priority_queue<typename> name;
这里的typename可以是任意基本数据类型或容器。
2. priority_queue容器内元素的访问
和队列不一样的是,优先队列只能通过top()函数访问队首元素(优先级最高的那个元素),时间复杂度为
#include <iostream>
#include <queue>
using namespace std;
int main() {
priority_queue<int> ay;
ay.push(3);
ay.push(6);
ay.push(2);
cout << ay.top() << endl;
return 0;
}
/*
result: 6
*/
3. priority_queue常用函数实例解析
(0)top()
获得队首元素,示例如上。
(1)push()与pop()
push(x)使得x入队,pop(x)使队首元素(堆顶元素)出队,时间复杂度均为,其中为当前优先队列中的元素个数。
示例如下:
#include <iostream>
#include <queue>
using namespace std;
int main() {
priority_queue<int> ay;
ay.push(3);
ay.push(6);
ay.push(2);
for(int i = 1; i <= 3; i ++) {
cout << ay.top() << ' ';
ay.pop();
}
return 0;
}
/*
result: 6 3 2
*/
(2)empty()
empty()检测优先队列是否为空,返回true则空,返回false则非空。时间复杂度为。
#include <iostream>
#include <queue>
using namespace std;
int main() {
priority_queue<int> ay;
ay.push(3);
ay.push(6);
ay.push(2);
for(int i = 1; i <= 3; i ++) {
ay.pop();
if(ay.empty() == true) cout << "Empty" << ' ';
else cout << "Not Empty" << ' ';
}
return 0;
}
/*
result: Not Empty Not Empty Empty
*/
(3)size()
返回优先队列内元素的个数,时间复杂度为O(1)。
示例如下:
#include <iostream>
#include <queue>
using namespace std;
int main() {
priority_queue<int> ay;
ay.push(3);
ay.push(6);
ay.push(2);
for(int i = 1; i <= 3; i ++) {
ay.pop();
cout << ay.size() << ' ';
}
return 0;
}
/*
result: 2 1 0
*/
4. priority_queue内元素优先级的设置
(1)基本数据类型的优先级设置
此处指的基本数据类型是int、double、char等可以直接使用的数据类型,优先队列对它们的优先级设置一般是数字大的优先级越高,因此队首元素就是优先队列内元素最大的那个(如果是char,则是字典序最大的)。对基本数据类型来说,底下两种定义方式是等价的:
priority_queue<int> ay;
priority_queue<int, vector<int>, less<int> > ay;
第二种定义方式中的第二个参数填写的是用来承载底层数据结构堆的容器,vector里面的数据类型与优先队列自己的数据类型保持一致。less<int>表示数字大的优先级越大,而greater<int>表示数字小的优先级越大。
#include <queue>
#include <iostream>
using namespace std;
int main() {
priority_queue<int, vector<int>, greater<int> > ay;
ay.push(2);
ay.push(4);
ay.push(1);
cout << ay.top() << endl;
return 0;
}
/*
result: 1
*/
(2)结构体的优先级设置
本文最开头举了水果的例子,可以对水果名称和价格建立一个结构体,我们希望按水果价格高的为优先级高。这就需要重载(overload)小于号“<”。这里读者只需要知道其写法即可。
#include <iostream>
#include <queue>
#include <string>
using namespace std;
struct fruit{
string name;
int price;
friend bool operator < (fruit f1, fruit f2) {
return f1.price > f2.price;
}
}f1, f2, f3;
int main() {
priority_queue<fruit> q;
f1.name = "peach";
f1.price = 6;
f2.name = "apple";
f2.price = 4;
f3.name = "orange";
f3.price = 3;
q.push(f1);
q.push(f2);
q.push(f3);
cout << q.top().name << endl;
return 0;
}
/*
result: orange
*/
这里需要注意,重载的作用与sort的cmp函数是相反的。比如上面我们将价格从大到小排序,队首元素却是价格最低的。反之亦然。原因在于优先队列默认规则为优先级高的放在队首,小于号重载成大于号只是将规则反向了一下。
最后,数据量大的时候建议使用引用来提高效率,如下:
friend bool operator < (const fruit &f1, const fruit f2) {
return f1.price < f2.price;
}
本文标签: 详解常见stlpriorityqueue
版权声明:本文标题:[STL]priority_queue的常见用法详解 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dianzi/1728896293a1178452.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论