栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

STL优先对列用法(int和pair)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

STL优先对列用法(int和pair)

1.基本操作:

empty()    如果队列为空,则返回真

pop()    删除对顶元素,删除第一个元素

push()    加入一个元素

size()     返回优先队列中拥有的元素个数

top()     返回优先队列对顶元素,返回优先队列中有最高优先级的元素

2.声明

1)头文件

2)priority_queue q; 默认大顶堆。(top()弹出最大值)

priority_queue,greater > q; 小顶堆写法(top()弹出最小值)

以下是以pair:

priority_queue q;

priority_queue,greater > (比较的是pair.first)

(PS:注意pair需要头文件

3.代码演示

#include 
#include 
#include 
#include 
using namespace std;
typedef pair PII;

int main()
{
	priority_queue q1;
	priority_queue,greater > q2;
	priority_queue q3;
	priority_queue,greater > q4;
	if(q1.empty()) cout<<"此队列为空"< 

(PS:c++11支持push({100,25}),如果有编译错误,请换成make_pair(别问我是怎么知道的!!!))

4.一道例题

https://codeforces.com/problemset/problem/1526/C2https://codeforces.com/problemset/problem/1526/C2ac代码

#include 
#include 
#include 
#include 
using namespace std;
 
int a[200010];
int main()
{
	priority_queue, greater > c;
	int n,i,j=0,num=0;
	long long sum=0;
	cin>>n;
	for(i=0;i>a[i];
	for(i=0;i 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/767592.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号