标准模板库(STL)学习指南之priority_queue优先队列
转载自CSDN博客:http://blog.csdn.net/suwei19870312/article/details/5294016
priority_queue 调用 STL里面的 make_heap(), pop_heap(), push_heap() 算法
实现,也算是堆的另外一种形式。
先写一个用 STL 里面堆算法实现的与真正的STL里面的 priority_queue 用法相
似的 priority_queue, 以加深对 priority_queue 的理解
- #include <iostream>
- #include <algorithm>
- #include <vector>
- using namespace std;
- class priority_queue
- {
- private:
- vector<int> data;
- public:
- void push( int t ){
- data.push_back(t);
- push_heap( data.begin(), data.end());
- }
- void pop(){
- pop_heap( data.begin(), data.end() );
- data.pop_back();
- }
- int top() { return data.front(); }
- int size() { return data.size(); }
- bool empty() { return data.empty(); }
- };
- int main()
- {
- priority_queue test;
- test.push( 3 );
- test.push( 5 );
- test.push( 2 );
- test.push( 4 );
- while( !test.empty() ){
- cout << test.top() << endl;
- test.pop(); }
- return 0;
- }
STL里面的 priority_queue 写法与此相似,只是增加了模板及相关的迭代器什么的。
priority_queue 对于基本类型的使用方法相对简单。
他的模板声明带有三个参数,priority_queue<Type, Container, Functional>
Type 为数据类型, Container 为保存数据的容器,Functional 为元素比较方式。
Container 必须是用数组实现的容器,比如 vector, deque 但不能用 list.
STL里面默认用的是 vector. 比较方式默认用 operator< , 所以如果你把后面俩个
参数缺省的话,优先队列就是大顶堆,队头元素最大。
看例子
- #include <iostream>
- #include <queue>
- using namespace std;
- int main(){
- priority_queue<int> q;
- for( int i= 0; i< 10; ++i ) q.push( rand() );
- while( !q.empty() ){
- cout << q.top() << endl;
- q.pop();
- }
- getchar();
- return 0;
- }
STL里面定义了一个仿函数 greater<>,对于基本类型可以用这个仿函数声明小顶堆
例子:
- #include <iostream>
- #include <queue>
- using namespace std;
- int main(){
- priority_queue<int, vector<int>, greater<int> > q;
- for( int i= 0; i< 10; ++i ) q.push( rand() );
- while( !q.empty() ){
- cout << q.top() << endl;
- q.pop();
- }
- getchar();
- return 0;
- }
先看看例子:
- #include <iostream>
- #include <queue>
- 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 ){
- if( a.x== b.x ) return a.y> b.y;
- return a.x> b.x;
- }
- int main(){
- priority_queue<Node> 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();
- }
- getchar();
- return 0;
- }
自定义类型重载 operator< 后,声明对象时就可以只带一个模板参数。
但此时不能像基本类型这样声明
priority_queue<Node, vector<Node>, greater<Node> >;
原因是 greater<Node> 没有定义,如果想用这种方法定义
则可以按如下方式
例子:
- #include <iostream>
- #include <queue>
- using namespace std;
- struct Node{
- int x, y;
- Node( int a= 0, int b= 0 ):
- x(a), y(b) {}
- };
- struct cmp{
- bool operator() ( Node a, Node b ){
- if( a.x== b.x ) return a.y> b.y;
- return a.x> b.x; }
- };
- int main(){
- priority_queue<Node, vector<Node>, cmp> 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();
- }
- getchar();
- return 0;
- }
标准模板库(STL)学习指南之priority_queue优先队列的更多相关文章
- 标准模板库(STL)学习指南之sort排序
对于程序员来说,数据结构是必修的一门课.从查找到排序,从链表到二叉树,几乎所有的算法和原理都需要理解,理解不了也要死记硬背下来.幸运的是这些理论都已经比较成熟,算法也基本固定下来,不需要你再去花费心思 ...
- 标准模板库(STL)学习指南之List链表
本文转载自天极网,原文地址:http://www.yesky.com/255/1910755.shtml.转载请注明 什么是STL呢?STL就是Standard Template Library,标准 ...
- 标准模板库(STL)学习指南之set集合
set是关联容器.其键值就是实值,实值就是键值,不可以有重复,所以我们不能通过set的迭代器来改变set的元素的值,set拥有和list相同的特性:当对他进行插入和删除操作的时候,操作之前的迭代器依然 ...
- 标准模板库(STL)学习指南之map映射
转载自CSDN博客:http://blog.csdn.net/bat603/article/details/1456141 Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关 ...
- 标准模板库(STL)学习指南之vector向量
vector – 一. vector可以模拟动态数组 – 二. vector的元素可以是任意类型T,但必须具备赋值和拷贝能力(具有public 拷贝构造函数和重载的赋值操作符) 三.必须包含的头文 ...
- 标准模板库(STL)学习探究之stack
标准模板库(STL)学习探究之stack queue priority_queue list map/multimap dequeue string
- 标准模板库(STL)学习探究之vector容器
标准模板库(STL)学习探究之vector容器 C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...
- 标准模板库(STL)学习探究之Multimap容器
C++ Multimaps和maps很相似,但是MultiMaps允许重复的元素.(具体用法请参考map容器) 函数列表: begin() 返回指向第一个元素的迭代器 cle ...
- STL学习系列之一——标准模板库STL介绍
库是一系列程序组件的集合,他们可以在不同的程序中重复使用.C++语言按照传统的习惯,提供了由各种各样的函数组成的库,用于完成诸如输入/输出.数学计算等功能. 1. STL介绍 标准模板库STL是当今每 ...
随机推荐
- RedisTemplate访问Redis数据结构(介绍和常用命令)
Redis 数据结构简介 Redis 可以存储键与5种不同数据结构类型之间的映射,这5种数据结构类型分别为String(字符串).List(列表).Set(集合).Hash(散列)和 Zset(有序集 ...
- Xshell连接不上行Linux系统
之前出现了.我的Linux系统上的主机可以ping通windows的一台电脑, windows也可以ping的通Linux.但是Xshell不能连接. 第一,我感觉是不是我Linux系统的端口被防火墙 ...
- 【模式识别】CART和GML AdaBoost MATLAB TOOLBOX
GML AdaBoost Matlab Toolbox是一款很优秀的AdaBoost工具箱,内部实现了Real AdaBoost, Gentle AdaBoost和Modest AdaBoost三种方 ...
- JDBC【菜鸟学JAVA】
1:首先下载sqljdbc.jar,然后配置ClassPath,然后再在工程文件中把这个(sqljdbc.jar)架包引用上,就可以开始JAVA操作之旅了 打开Eclipse,“文件”→“新建”→“项 ...
- 搜索ABAP程序代码中的字符串
标准程序名:RPR_ABAP_SOURCE_SCAN /BEV1/NERM07DOCS
- activiti基础--1------------------------生成.bpmn和.png以及部署流程定义
helloworld.dbmn <?xml version="1.0" encoding="UTF-8"?> <definitions xml ...
- python 数据结构中被忽视的小技巧
一.一个包含N个元素的字符串.元组.序列.以及任何可迭代对象均可以拆分成N个单独的“变量” 1.字符串的拆分 #字符串 In [10]: s="abdefg" In [11]: o ...
- python基础18 ---多态与绑定方法
一.抽象类 1.抽象类的定义:从一堆类中抽象出相同的内容,重新组成一个新的类,这样的类属于抽象类. 2.香蕉类是一类水果,苹果类是一类水果,葡萄类是一类水果,但是他们都属于水果,从他们这些类中可以抽象 ...
- python基础17 ---继承补充知识
一.继承的顺序 1.在python中的类可以集成多个类,既然是继承多个类就有类的寻找顺序这么一说.其寻找方法就有广度优先和深度优先两种. 2.当类是新式类,多继承的情况下会按照广度优先的顺序查找. 如 ...
- python SimpleHTTPServer 快速共享文件
简单介绍 通过一个python命令快速共享文件给他人. 操作步骤 1.打开cmd命令行,切换到需要共享文件的目录,执行命令 python -m SimpleHTTPServer . 2.打开浏览器,在 ...