转自:http://www.cnblogs.com/summerRQ/articles/2470130.html

STL容器之优先队列

优先级队列,以前刷题的时候用的比较熟,现在竟然我只能记得它的关键字是priority_queue(太伤了)。在一些定义了权重的地方这个数据结构是很有用的。

先回顾队列的定义:队列(queue)维护了一组对象,进入队列的对象被放置在尾部,下一个被取出的元素则取自队列的首部。priority_queue特别之处在于,允许用户为队列中存储的元素设置优先级。这种队列不是直接将新元素放置在队列尾部,而是放在比它优先级低的元素前面。标准库默认使用<操作符来确定对象之间的优先级关系,所以如果要使用自定义对象,需要重载 < 操作符。

优先队列有两种,一种是最大优先队列;一种是最小优先队列;每次取自队列的第一个元素分别是优先级最大和优先级最小的元素。

1) 优先队列的定义

包含头文件:"queue.h", "functional.h"

可以使用具有默认优先级的已有数据结构;也可以再定义优先队列的时候传入自定义的优先级比较对象;或者使用自定义对象(数据结构),但是必须重载好< 操作符。

2) 优先队列的常用操作

优先级队列支持的操作

q.empty()         如果队列为空,则返回true,否则返回false

q.size()            返回队列中元素的个数

q.pop()             删除队首元素,但不返回其值

q.top()             返回具有最高优先级的元素值,但不删除该元素

q.push(item)     在基于优先级的适当位置插入新元素

其中q.top()为查找操作,在最小优先队列中搜索优先权最小的元素,在最大优先队列中搜索优先权最大的元素。q.pop()为删除该元素。优先队列插入和删除元素的复杂度都是O(lgn),所以很快

另外,在优先队列中,元素可以具有相同的优先权。

下面这个C例子,包含了几乎所有常见的优先队列用法。

  1. #include<iostream>
  2. #include<functional>
  3. #include<queue>
  4. #include<vector>
  5. using namespace std;
  6.  
  7. //定义比较结构
  8. struct cmp1{
  9. bool operator ()(int &a,int &b){
  10. return a>b;//最小值优先
  11. }
  12. };
  13.  
  14. struct cmp2{
  15. bool operator ()(int &a,int &b){
  16. return a<b;//最大值优先
  17. }
  18. };
  19.  
  20. //自定义数据结构
  21. struct number1{
  22. int x;
  23. bool operator < (const number1 &a) const {
  24. return x>a.x;//最小值优先
  25. }
  26. };
  27. struct number2{
  28. int x;
  29. bool operator < (const number2 &a) const {
  30. return x<a.x;//最大值优先
  31. }
  32. };
  33. int a[]={14,10,56,7,83,22,36,91,3,47,72,0};
  34. number1 num1[]={14,10,56,7,83,22,36,91,3,47,72,0};
  35. number2 num2[]={14,10,56,7,83,22,36,91,3,47,72,0};
  36.  
  37. int main()
  38. {
  39. priority_queue<int>que;//采用默认优先级构造队列
  40.  
  41. priority_queue<int,vector<int>,cmp1>que1;//最小值优先
  42. priority_queue<int,vector<int>,cmp2>que2;//最大值优先
  43.  
  44. priority_queue<int,vector<int>,greater<int> >que3;//注意“>>”会被认为错误,
  45. priority_queue<int,vector<int>,less<int> >que4;////最大值优先
  46.  
  47. priority_queue<number1>que5; //最小优先级队列
  48. priority_queue<number2>que6; //最大优先级队列
  49.  
  50. int i;
  51. for(i=0;a[i];i++){
  52. que.push(a[i]);
  53. que1.push(a[i]);
  54. que2.push(a[i]);
  55. que3.push(a[i]);
  56. que4.push(a[i]);
  57. }
  58. for(i=0;num1[i].x;i++)
  59. que5.push(num1[i]);
  60. for(i=0;num2[i].x;i++)
  61. que6.push(num2[i]);
  62.  
  63. printf("采用默认优先关系:/n(priority_queue<int>que;)/n");
  64. printf("Queue 0:/n");
  65. while(!que.empty()){
  66. printf("%3d",que.top());
  67. que.pop();
  68. }
  69. puts("");
  70. puts("");
  71.  
  72. printf("采用结构体自定义优先级方式一:/n(priority_queue<int,vector<int>,cmp>que;)/n");
  73. printf("Queue 1:/n");
  74. while(!que1.empty()){
  75. printf("%3d",que1.top());
  76. que1.pop();
  77. }
  78. puts("");
  79. printf("Queue 2:/n");
  80. while(!que2.empty()){
  81. printf("%3d",que2.top());
  82. que2.pop();
  83. }
  84. puts("");
  85. puts("");
  86. printf("采用头文件/"functional/"内定义优先级:/n(priority_queue<int,vector<int>,greater<int>/less<int> >que;)/n");
  87. printf("Queue 3:/n");
  88. while(!que3.empty()){
  89. printf("%3d",que3.top());
  90. que3.pop();
  91. }
  92. puts("");
  93. printf("Queue 4:/n");
  94. while(!que4.empty()){
  95. printf("%3d",que4.top());
  96. que4.pop();
  97. }
  98. puts("");
  99. puts("");
  100. printf("采用结构体自定义优先级方式二:/n(priority_queue<number>que)/n");
  101. printf("Queue 5:/n");
  102. while(!que5.empty()){
  103. printf("%3d",que5.top());
  104. que5.pop();
  105. }
  106. puts("");
  107. printf("Queue 6:/n");
  108. while(!que6.empty()){
  109. printf("%3d",que6.top());
  110. que6.pop();
  111. }
  112. puts("");
  113. return 0;
  114. }
  115. /*
  116. 运行结果 :
  117. 采用默认优先关系:
  118. (priority_queue<int>que;)
  119. Queue 0:
  120. 91 83 72 56 47 36 22 14 10 7 3
  121.  
  122. 采用结构体自定义优先级方式一:
  123. (priority_queue<int,vector<int>,cmp>que;)
  124. Queue 1:
  125. 3 7 10 14 22 36 47 56 72 83 91
  126. Queue 2:
  127. 91 83 72 56 47 36 22 14 10 7 3
  128.  
  129. 采用头文件"functional"内定义优先级:
  130. (priority_queue<int,vector<int>,greater<int>/less<int> >que;)
  131. Queue 3:
  132. 3 7 10 14 22 36 47 56 72 83 91
  133. Queue 4:
  134. 91 83 72 56 47 36 22 14 10 7 3
  135.  
  136. 采用结构体自定义优先级方式二:
  137. (priority_queue<number>que)
  138. Queue 5:
  139. 3 7 10 14 22 36 47 56 72 83 91
  140. Queue 6:
  141. 91 83 72 56 47 36 22 14 10 7 3
  142. */

STL_优先队列_(转载)的更多相关文章

  1. 算法竞赛中的常用JAVA API:PriorityQueue(优先队列)(转载)

    算法竞赛中的常用JAVA API:PriorityQueue(优先队列) PriorityQueue 翻译过来就是优先队列,本质是一个堆, 默认情况下堆顶每次都保留最小值,每插入一个元素,仍动态维护堆 ...

  2. 前端CSS规范整理_转载、、、

    一.文件规范 1.文件均归档至约定的目录中. 具体要求通过豆瓣的CSS规范进行讲解: 所有的CSS分为两大类:通用类和业务类.通用的CSS文件,放在如下目录中: 基本样式库 /css/core 通用U ...

  3. Java垃圾回收机制_(转载)

    Java垃圾回收机制 说到垃圾回收(Garbage Collection,GC),很多人就会自然而然地把它和Java联系起来.在Java中,程序员不需要去关心内存动态分配和垃圾回收的问题,这一切都交给 ...

  4. Java_类和对象(完美总结)_转载_覆盖和隐藏的区别,覆盖就不能使用了,而隐藏提供全局方法名或者全局变量名还可以使用

    转载自海子:http://www.cnblogs.com/dolphin0520/p/3803432.html Java:类与继承 对于面向对象的程序设计语言来说,类毫无疑问是其最重要的基础.抽象.封 ...

  5. VS连接SQL Server数据库,增删改查详细教程(C#代码)_转载

    工具: 1.Visual Studio (我使用的是vs2013) 2.SQL Server  (我使用的是sql server2008) 操作: 1.打开SQL Server,打开后会看到数据库的初 ...

  6. luogu P5290 [十二省联考2019]春节十二响 优先队列_启发式合并

    思维难度不大,在考上上写的启发式合并写错了,只拿了 60 pts,好难过QAQ 没什么太难的,在考场上想出链的部分分之后很容易就能想到正解.没错,就是非常短的启发式合并.注意一下,写的要漂亮一点,否则 ...

  7. 三分钟学会用SpringMVC搭建最小系统(超详细)_转载

    前言 做 Java Web 开发的你,一定听说过SpringMVC的大名,作为现在运用最广泛的Java框架,它到目前为止依然保持着强大的活力和广泛的用户群. 本文介绍如何用eclipse一步一步搭建S ...

  8. Dijstra_优先队列_前向星

    Dijstra算法求最短路径 具体实现方式 设置源点,将源点从原集u{}中取出并放入新建集s{} 找出至源点最近的点q从原集取出放入新集s{} 由q点出发,更新所有由q点能到达的仍处于原集的点到源点的 ...

  9. STL_优先队列

    一.简介 优先队列容器与队列一样,只能从队尾插入元素,从队首删除元素.但是它有一个特性,就是队列中最大的元素总是位于队首,所以出队时,并非按照先进先出的原则进行,而是将当前队列中最大的元素出队. 元素 ...

随机推荐

  1. Javascript网址跳转方法

    第一种: window.location.href="http://www.baidu.com"; 第二种: window.navigate("http://www.ba ...

  2. Dalvik虚拟机总结

    一.Dalvik虚拟机启动 在启动Zygote进程时,会启动Dalvik虚拟机,完毕以下几件事: 1. 创建了一个Dalvik虚拟机实例: 2. 载入了Java核心类及注冊其JNI方法: 3. 为主线 ...

  3. 1. 数组小挪移CyclicRotation Rotate an array to the right by a given number of steps.

    数组小挪移: package com.code; import java.util.Arrays; public class Test02_2 { public int[] solution(int[ ...

  4. [React Native] Prevent the On-screen Keyboard from Covering up Text Inputs

    When you bring up the on screen keyboard in a mobile app, it will cover any text input or buttons on ...

  5. Swift之闭包

    swift中闭包是一个非常强大的东西,闭包是自包括的函数代码块,能够在代码中被传递和使用.跟C 和 Objective-C 中的代码块(blocks)非常相似 .这个大家必须掌握!必须掌握! 必须掌握 ...

  6. 解决安装OpenShift Client Tools时提示的dl/import (LoadError)问题

    安装成功Ruby和git以后.执行rhc setup时提演示样例如以下错误: C:/Ruby22-x64/lib/ruby/2.2.0/rubygems/core_ext/kernel_require ...

  7. Java读取数据库数据生成柱状图

    此案例是用swing显示数据的.须要引入jfreechart相关包.不同版本号可能包不同样.本人用的是 此案例在ssi框架下会报错,不用框架就没问题. Java后台逻辑代码: public class ...

  8. 行政区划代码(SQL版本)2018年8月

    表结构:(新建好表字段即可直接copy insert SQL语句) SQL语句: INSERT INTO z_regioncode(regioncode,regionname,pcode) VALUE ...

  9. bzoj1143: [CTSC2008]祭祀river && bzoj27182718: [Violet 4]毕业旅行

    其实我至今不懂为啥强联通缩点判入度会错... 然后这个求的和之前那道组合数学一样,就是最长反链=最小链覆盖=最大独立集. #include<cstdio> #include<iost ...

  10. Coursera Algorithms week4 基础标签表 练习测验:Java autoboxing and equals

    1. Java autoboxing and equals(). Consider two double values a and b and their corresponding Double v ...