博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
STL优先队列模板
阅读量:6305 次
发布时间:2019-06-22

本文共 970 字,大约阅读时间需要 3 分钟。

1. 优先队列

用途:按照某一个关键字对插入元素或删除元素后的数据集进行自动排序

复杂度: logN

2. 数据声明

(1)头文件:#include<queue>

(2)声明:  priority_queue <T> q; //T是一个泛型,可以是结构体

       priority_queue <T,vector<T>,greater<T> > q;

  greater函数也可以通过对结构体重载一个<运算符的bool函数

3. 库函数

q.size();//返回q里元素个数q.empty();//返回q是否为空,空则返回1,否则返回0q.push(k);//在q的末尾插入kq.pop();//删掉q的第一个元素q.top();//返回q的第一个元素q.back();//返回q的末尾元素

 

4. 实例

#include 
#include
using namespace std;struct Node{ int x, y; Node(int a=0, int b=0): x(a),y(b){}};bool operator<(Node a, Node b){
//返回true时,说明a的优先级低于b //x值较大的Node优先级低(x小的Node排在队前) //x相等时,y大的优先级低(y小的Node排在队前) if( a.x== b.x ) return a.y> b.y; return a.x> b.x; }int main(){ priority_queue
q; for( int i= 0; i< 10; ++i ) q.push( Node( rand(), rand() ) ); while( !q.empty() ){ cout << q.top().x << ' ' << q.top().y << endl; q.pop(); } return 0;}

 

转载于:https://www.cnblogs.com/czsharecode/p/10502281.html

你可能感兴趣的文章
springboot使用schedule定时任务
查看>>
[转] Entity Framework Query Samples for PostgreSQL
查看>>
XDUOJ 1115
查看>>
PHP学习(四)---PHP与数据库MySql
查看>>
模版方法模式--实现的capp流程创建与管理
查看>>
软件需求分析的重要性
查看>>
eclipse的scala环境搭建
查看>>
UVA465:Overflow
查看>>
HTML5-placeholder属性
查看>>
Android选择本地图片过大程序停止的经历
查看>>
poj 2187:Beauty Contest(旋转卡壳)
查看>>
《Flask Web开发》里的坑
查看>>
Python-库安装
查看>>
Git笔记
查看>>
普通人如何从平庸到优秀,在到卓越
查看>>
SLAM数据集
查看>>
c#学习笔记05——数组&集合
查看>>
【图论算法】Dijstra&BFS
查看>>
注册和上传文件(头像)
查看>>
使用OVS
查看>>