C++ STL 优先队列 (priority_queue)
std::priority_queue
<queue>
优先队列
优先队列是一种容器适配器,根据某些严格的弱排序标准,使其第一个元素始终包含的最大元素。
这种特性类似于堆,它可以在其中随时插入元素,并且只能检索最大堆元素(即优先级队列顶部的元素)。
优先队列内部的实现需要依赖基础容器,该容器应可通过随机访问[i]和迭代器Iterator访问,并需要支持以下操作
empty( )size( )front( )push_back( )pop_back( )
显而易见的是有deque和vector这两个基础容器支持以上操作
所以在默认情况下,如果未为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;
}

C++ STL 优先队列 (priority_queue)的更多相关文章
- C++ STL 优先队列 priority_queue 详解(转)
转自https://blog.csdn.net/c20182030/article/details/70757660,感谢大佬. 优先队列 引入 优先队列是一种特殊的队列,在学习堆排序的时候就有所了解 ...
- 【C++ STL 优先队列priority_queue】
https://www.cnblogs.com/fzuljz/p/6171963.html
- 【STL】优先队列priority_queue详解+OpenJudge-4980拯救行动
一.关于优先队列 队列(queue)这种东西广大OIer应该都不陌生,或者说,队列都不会你还学个卵啊(╯‵□′)╯︵┻━┻咳咳,通俗讲,队列是一种只允许从前端(队头)删除元素.从后端(队尾)插入元素的 ...
- 浅谈C++ STL中的优先队列(priority_queue)
从我以前的博文能看出来,我是一个队列爱好者,很多并不是一定需要用队列实现的算法我也会采用队列实现,主要是由于队列和人的直觉思维的一致性导致的. 今天讲一讲优先队列(priority_queue),实际 ...
- STL之priority_queue(优先队列)
priority_queue是一个容器适配器,在这个容器里第一个数据元素是最大的.它的使用场景是什么样:如果12306抢票,为什么黄牛能抢这么多票,感觉12306那边的请求队列是一个优先队列,黄牛的请 ...
- CJOJ 2484 函数最小值 / Luogu 2085 函数最小值(STL优先队列,堆)
CJOJ 2484 函数最小值 / Luogu 2085 函数最小值(STL优先队列,堆) Description 有n个函数,分别为F1,F2,...,Fn.定义 \(Fi(x)=Aix^2+Bix ...
- CJOJ 2482 【POI2000】促销活动(STL优先队列,大根堆,小根堆)
CJOJ 2482 [POI2000]促销活动(STL优先队列,大根堆,小根堆) Description 促销活动遵守以下规则: 一个消费者 -- 想参加促销活动的消费者,在账单下记下他自己所付的费用 ...
- 基于STL优先队列和邻接表的dijkstra算法
首先说下STL优先队列的局限性,那就是只提供入队.出队.取得队首元素的值的功能,而dijkstra算法的堆优化需要能够随机访问队列中某个节点(来更新源点节点的最短距离). 看似可以用vector配合m ...
- poj 3253 Fence Repair (STL优先队列)
版权声明:本文为博主原创文章,未经博主同意不得转载. vasttian https://blog.csdn.net/u012860063/article/details/34805369 转载请注明出 ...
随机推荐
- windows 上的MySQL默认字符集设置踩过的坑
前言: 前几天刚买了新电脑,装上MySQL有几天了,今天没事试了一下,发现默认字符集没有修改,还是默认的latin1,折腾了大半天,终于搞好了. 这是我成功设置后的结果图: 命令式直接在MySQL界面 ...
- securecrt7.1注册方法
本文出自 "Kinslayer 's Blog" 博客,请务必保留此出处http://kinslayer.blog.51cto.com/3681810/833438
- Numpy的学习5-array的分割
import numpy as np A = np.arange(12).reshape((3, 4)) print(A) """ array([[ 0, 1, 2, 3 ...
- Spring Cloud 入门教程(一): Eureka 服务注册
创建一个Maven工程,New-Other-Maven-Maven Probject 点击Next,红色框里的选上 点击Next 点击Finsh就完成了一个Maven Probject的创建. (1) ...
- day019python之面向对象基础1
面向对象基础 目录 面向对象基础 1 面向对象基础 1.1 面向对象的由来 1.2 面向对象编程介绍 1.2.1 回顾面向过程设计 1.2.2 面向对象设计 2 类与对象 2.1 基本使用 2.2 示 ...
- Docker来搭建分布式文件系统FastDfs
对于文件存储来说,一般情况下简单的处理就是在Django配置文件中配置存储目录,按照规则对文件进行上传或者下载. 实际上,当文件较少的时候,Django是可以应付的过来的.但当文件以海量形式出现的时候 ...
- python爬虫之解析链接
解析链接 1. urlparse() & urlunparse() urlparse() 是对url链接识别和分段的,API用法如下: urllib.parse.urlparse(urlstr ...
- 【Python 1-8】Python手把手教程之——管理列表List
遍历列表 在日常开发中,我们经常需要遍历列表的所有元素,对每个元素执行相同的操作.例如,在管理商场的蔬菜时候,需要给所有的蔬菜商品都打7折,并重新生成价格.当我们需要对列表中的每个元素都执行相同的操作 ...
- Unity 2017 Scene界面与Game界面显示不同/过于灰暗的解决办法
场景界面的显示过于灰暗,严重影响工作心情. 切换到游戏界面时的颜色. 只要将场景中全部摄像机的[Allow HDR]取消勾选即可.
- String 和 StringBuffer,StringBuilder 的区别
String 和 StringBuffer,StringBuilder 的区别 String 是 " 字符串常量" , 对象一旦创建就不可改变,这就导致如果字符串常量池中没有所需对 ...
