std::priority_queue

<queue>

优先队列

  优先队列是一种容器适配器,根据某些严格的弱排序标准,使其第一个元素始终包含的最大元素。

  这种特性类似于堆,它可以在其中随时插入元素,并且只能检索最大堆元素(即优先级队列顶部的元素)。

  优先队列内部的实现需要依赖基础容器,该容器应可通过随机访问[i]和迭代器Iterator访问,并需要支持以下操作

  • empty( )

  • size( )

  • front( )

  • push_back( )

  • pop_back( )

     显而易见的是有dequevector这两个基础容器支持以上操作

     所以在默认情况下,如果未为priority_queue指定基础容器类,则将使用vector

成员函数

(constructor) Construct priority queue (public member function )
empty 优先队列是否为空
size 返回优先队列的当前元素个数
top 访问顶部元素(返回顶部元素的常量引用)
push 插入一个元素
pop 删除顶部元素
emplace 构造并插入一个元素
void swap (priority_queue& x) 交换两个队列的内容

注:

1、emplace 与 push 相比更加优化了对内存空间的使用,具体可以另行查询

2、swap 是交换两个同一类型的优先队列内的所有元素,如 a.swap ( x ) 即交换队列 a 和 x 的所有元素

构造优先队列

        <queue>
/* 1 */ priority_queue<int> pq1; //默认大根堆且默认基础容器为vector
/* 2 */ priority_queue<vector<int>, less<int> > pq2; //与 1 的性质一模一样
/* 3 */ priority_queue<deque<int>, greater<int> > pq3; //小根堆且基础容器为deque

注意:大根堆为less,小根堆为greater

函数成员用例

1、push、top、empty、、pop、大根堆

(1)int
#include <iostream>
#include <queue> using namespace std; int main ( void )
{
priority_queue<int> pq; //大根堆,默认降序(大的在前,小的在后) pq.push ( 60 );
pq.push ( 20 );
pq.push ( 40 );
pq.push ( 1 );
pq.push ( 25 ); while ( !pq.empty() ) // pq不为空则循环
{
cout << pq.top() << " "; //添加新元素
pq.pop(); //弹出头元素
} return 0;
}

(2)string
#include <iostream>
#include <queue> using namespace std; int main ( void )
{
priority_queue<string> pq; //大根堆,默认降序(大的在前,小的在后) pq.push ( "abc" );
pq.push ( "abd" );
pq.push ( "acd" );
pq.push ( "cda" );
pq.push ( "abcd" ); while ( !pq.empty() ) // pq不为空则循环
{
cout << pq.top() << endl; //添加新元素
pq.pop(); //弹出头元素
} return 0;
}

输出按字典序

2、swap、emplace、小根堆

#include <iostream>
#include <queue> using namespace std; int main ( void )
{
priority_queue<int, vector<int>, greater<int> > pq1; //小根堆,默认降序(小的在前,大的在后) pq1.emplace ( 5 );
pq1.emplace ( 4 );
pq1.emplace ( 3 );
pq1.emplace ( 2 );
pq1.emplace ( 1 ); priority_queue<int, vector<int>, greater<int> > pq2; pq2.emplace ( 5 * 2 );
pq2.emplace ( 4 * 2 );
pq2.emplace ( 3 * 2 );
pq2.emplace ( 2 * 2 );
pq2.emplace ( 1 * 2 ); cout << "pq1:" << endl;
while ( !pq1.empty() ) // pq不为空则循环
{
cout << pq1.top() << " "; //添加新元素
pq1.pop(); //弹出头元素
} cout << endl << "pq2:" << endl;
while ( !pq2.empty() ) // pq不为空则循环
{
cout << pq2.top() << " "; //添加新元素
pq2.pop(); //弹出头元素
}
cout << endl; return 0;
}

最新文章

  1. 模拟n个人参加选举的过程,并输出选举结果:假设候选人有四人,分别用A,B,C,D表示,当选某候选人时,直接输入其编号(编号由计算机随机产生,若输入的不是A,B,C,D则视为无效票,选举结束后按得票数从高到底输出候选人编号和所得票数.
  2. vc中获取磁盘IO统计计数
  3. Centos安装Kafka集群
  4. Linux学习新篇——常用命令和快捷键总结
  5. JVM中java类的加载时机(转载:http://blog.csdn.net/chenleixing/article/details/47099725)
  6. Spring MVC 教程(比较全的一篇文章了)
  7. 利用qq设置个性化的域名邮箱
  8. openstack-ocata-环境准备1
  9. 机器学习基石:13 Hazard of Overfitting
  10. jquery瀑布流排列样式代码
  11. java Quartz任务调度器
  12. Python3练习题 021:递归方法求阶乘
  13. 在Windows上搭建Git Server
  14. 从零开始学 Web 之 移动Web(五)touch事件的缺陷,移动端常用插件
  15. nginx实现tomcat的负载均衡及企业内部应用的代理
  16. 邂逅明下 HDU - 2897
  17. [Codeforces721E]Road to Home
  18. vue使用日期时间插件layDate
  19. cnn公式推导
  20. P4549 【模板】裴蜀定理

热门文章

  1. Graphql Tutorials(Episode 01)
  2. js上 五、运算符-1
  3. js下 Day10、尺寸位置属性
  4. MyBatisPlus-常用注解
  5. 又到期末了,为什么学完C语言觉得好像没学一般?复习资料来一份
  6. oracle 19c dataguard silent install (oracle 19c dataguard 静默安装)
  7. Mybatis【8】-- Mybatis返回List或者Map以及模糊查询怎么搞?
  8. 常用java自带命令概览
  9. Liunx运维(七)-用户管理及用户信息查询命令
  10. ArrayListHashmap嵌套