STL学习系列七:优先级队列priority_queue容器

时间:2022-05-23 23:37:05

1.简介

  • 最大值优先级队列、最小值优先级队列
  • 优先级队列适配器 STL priority_queue
  • 用来开发一些特殊的应用,请对stl的类库,多做扩展性学习

这里给个例子:

#include<iostream>
#include <algorithm>
#include<functional>
#include <queue>
using namespace std;
void objPlay()
{ priority_queue<int> p1; //默认是 最大值优先级队列
//priority_queue<int, vector<int>, less<int> > p1; //相当于这样写
priority_queue<int, vector<int>, greater<int> > p2; //最小值优先级队列 p1.push();
p1.push();
p1.push();
p1.push();
cout << "测试 最小值优先级队列" << endl;
cout << "队列大小" << p1.size() << endl;
cout << "队头" << p1.top() << endl; while (p1.size() > )
{
cout << p1.top() << " ";
p1.pop();
} cout << endl;
cout << "**************************" << endl; p2.push();
p2.push();
p2.push();
p2.push();
cout << "测试 最小值优先级队列" << endl;
cout << "队列大小" << p2.size() << endl;
cout << "队头" << p2.top() << endl;
while (p2.size() > )
{
cout << p2.top() << " ";
p2.pop(); }
cout << endl;
} int main()
{
objPlay(); system("pause");
return ;
}