原文地址:STL之priority_queue作者:李大宝

STL之优先队列

原本以为priority_queue很简单,才知道原来懂的只是最简单的形式。

头文件:#include<queue>

优先队列,也就是原来我们学过的堆,按照自己定义的优先级出队时。默认情况下底层是以Vector实现的heap。

既然是队列,也就只有入队、出队、判空、大小的操作,并不具备查找功能。

函数列表:
empty() 如果优先队列为空,则返回真 
pop() 删除第一个元素 
push() 加入一个元素 
size() 返回优先队列中拥有的元素的个数 
top() 返回优先队列中有最高优先级的元素

用途就不用多说了吧,例如Huffman编码、分支限界、A*启发式都需要用到优先队列存放信息。

来看最常用的几个功能,了解一下其中的知识点:

一:最基本的功能

#include<iostream>

#include<queue>

using namespace std;

int main()

{

priority_queue<int> Q;

Q.push(2);

Q.push(5);

Q.push(3);

while(!Q.empty())

{

cout<<Q.top()<<endl;

Q.pop();

}

system("pause");

return 0;

}

优先队列最基本的功能就是出队时不是按照先进先出的规则,而是按照队列中优先级顺序出队。

知识点:1、一般存放实型类型,可比较大小

2、默认情况下底层以Vector实现

3、默认情况下是大顶堆,也就是大者优先级高,后面可以自定义优先级比较规则

二:次基本的功能

#include<iostream>

#include<queue>

using namespace std;

int main()

{

int a[5]={3,4,5,2,1};

priority_queue<int> Q(a,a+5);

while(!Q.empty())

{

cout<<Q.top()<<endl;

Q.pop();

}

system("pause");

return 0;

}

可以将一个存放实型类型的数据结构转化为优先队列,这里跟优先队列的构造函数相关。

上面那个默认构造一个空的优先队列,什么都使用默认的。

而这里使用的是

Priority_queue(InputIterator first,InputIterator last)

我理解的就是给出了一个容器的开口和结尾,然后把这个容器内容拷贝到底层实现(默认vector)中去构造出优先队列。这里也使用了一个默认的比较函数,也是默认大顶堆

三 应该掌握的功能:

#include<iostream>

#include<queue>

using namespace std;

typedef pair<long,int> Node;

priority_queue< Node,vector< Node >,greater< Node > > Q;

这个里面定义了一个制定存放元素(Node),底层实现以vector实现(第二个参数),优先级为小顶堆(第三个参数)。

前两个参数没什么说的,很好理解,其中第三个参数,默认有三写法:

小顶堆:greater<TYPE>

大顶堆:less<TYPE>

如果想自定义优先级而TYPE不是基本类型,而是复杂类型,例如结构体、类对象,则必须重载其中的operator(),见下面的例子。

例子:

#include<iostream>

#include<queue>

using namespace std;

//模拟存放节点信息

typedef struct

{

int a;

int b;

}Node;

//自定义优先级类型

struct cmp

{

bool operator()(const Node &t1,const Node &t2)

{

return t1.b<t2.b;//相当于less,大顶堆

}

};

int main()

{

//初始化

int n;

cin>>n;

Node *arr=new Node[n];

for(int i=0;i<n;i++)

{

cin>>arr[i].a>>arr[i].b;

}

//定义优先队列 ,自定义优先级,跟Qsort里面自定义相似

priority_queue<Node,vector<Node>,cmp> Q(arr,arr+n);

while(!Q.empty())

{

Node n=Q.top();

cout<<n.a<<" "<<n.b<<endl;

Q.pop();

}

system("pause");

return 0;

}

一个例题就是ugly number

-------------------------------------------

Ugly numbers are numbers whose only prime factors are 2, 3 or 5. The sequence

1, 2, 3, 4, 5, 6, 8, 9, 10, 12, 15, ...

shows the first 11 ugly numbers. By convention, 1 is included.

Write a program to find and print the 1500'th ugly number.

转帖一个人写的使用优先队列解决的代码


#include <queue> 
using namespace std; 
typedef pair<unsigned long, int> node_type; 
main() 
{ 
unsigned long result[1500];
priority_queue< node_type, vector<node_type>, greater<node_type> > Q;
Q.push( make_pair(1, 2) ); 
for (int i=0; i<1500; i++) 
{
node_type node = Q.top(); 
Q.pop();
switch(node.second)
{ 
case 2: Q.push( make_pair(node.first*2, 2) );
case 3: Q.push( make_pair(node.first*3, 3) ); 
case 5: Q.push( make_pair(node.first*5, 5) );
} 
result[i] = node.first; 
}
int n;
cin >> n; 
while (n>0) 
{ 
cout << result[n-1] << endl;
cin >> n;
} 
return 1;
}

[转载]STL之priority_queue相关推荐

  1. [转载]STL之priority_queue_彭世瑜_新浪博客

    原文地址:STL之priority_queue作者:李大宝 STL之优先队列 原本以为priority_queue很简单,才知道原来懂的只是最简单的形式. 头文件:#include<queue& ...

  2. STL 中priority_queue小结

    (1)为了运用priority_queue,你必须包含头文件<queue>:#include<queue>    (2)在头文件中priority_queue定义如下: nam ...

  3. C++STL 优先队列priority_queue使用

    头文件:#include <queue> 一.申明方式 std::priority_queue<T> q; std::priority_queue<T, std::vec ...

  4. C++之STL之priority_queue

    1.priority_queue介绍 priority_queue 是优先队列 模板声明带有三个参数,priority_queue<Type, Container, Functional> ...

  5. 【C++ STL】priority_queue自定义排序函数

    priority_queue是C++的一种STL容器,实现为堆.在leetcode刷题中非常常用.有些时候我们需要塞入自定义的数据结构.这样就需要对其的排序方式做一个重新定义. 假设有以下数据结构 s ...

  6. STL——理解priority_queue

    文章目录 1.priority_queue基本介绍 2.priority_queue的常用接口及其使用 3.priority_queue模拟实现 3.1 仿函数Less和Great 3.2 adjus ...

  7. STL queue priority_queue

    queue 队列 queue 队列 就像排队一样,后来的排在后面,先来的先出队.所以只能对队首和队尾的元素进行操作 back() 返回最后一个元素 empty() 如果队列空则返回真 front() ...

  8. (STL,set,priority_queue)丑数

    题目: 丑数是指不能被2,3,5以外的其他素数整除的数.把丑数从小到大排列起来,结果如下:1,2,3,4,5,6,8,9,10,12,-求第1500个丑数 分析与解答: 0.对于任意丑数x:2x,3x ...

  9. python 利用高德地图定位小区名字

    1.利用地址定位到小区名字 这里调研的是利用高德的poi检索 开发文档地址:https://lbs.amap.com/api/webservice/guide/api/search 需要申请开放平台的 ...

最新文章

  1. Frameless - 用于预览 iOS8 原型的浏览器
  2. Package ‘oniguruma’, required by ‘virtual:world’, not found
  3. C++类实例以及子类在内存中的分配
  4. JAVA错误:无法从静态上下文中引用非静态变量 this
  5. C++智能指针中unique_ptr部分内容的讲解
  6. dremwere怎样让多个图片并列排放_国标双壁波纹管直径200、300、400、500、600、800图片展示...
  7. hdu 2570 (贪心)
  8. 小白都能看懂的numpy与pandas中axis解释
  9. STL学习笔记1--vector
  10. 一维码与二维码对比介绍
  11. Scratch3.0创意编程(基础篇):第10课 接苹果
  12. wifi良好,手机可以连接网络,电脑连接不上网络,解决方法
  13. android studio 导入module作为lib使用
  14. 倍福PLC获取伺服驱动器扭矩值获取电流值
  15. 计算机专业看重CPU还是显卡,电脑大神告诉你处理器和显卡哪个重要
  16. [RK3288][Android6.0] 不同分辨率的bootanimation.zip下载
  17. e7收费系统连接不到服务器,e7云服务器
  18. html页面改成jsp后IE和360浏览器不兼容问题
  19. oracle简单入门(全面)
  20. 祛痘方法层出不穷?羽素携专家共登《岭南大医生》揭痘肌修护玄机

热门文章

  1. pandas的apply方法基础使用
  2. NovAtel 板卡OEM617D配置步骤记录
  3. togaf 的4A架构
  4. 函数表达式与命名函数区别
  5. 野火iMX6ULL Pro开发板移植SDL2
  6. http://39.98.219.132 题库标准答案(题库序号:179)之判断素数
  7. 针对X5新内核Blink以及google chrome主要字体主动放大问题
  8. 网页链接分享到微信里的海报制作
  9. 推荐几款个人灰常喜欢的vscode 主题
  10. Mac外接磁盘使用哪种格式速度最快,NTFS?exFAT?HFS+?APFS?