普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除。在优先队列中,元素被赋予优先级。当访问元素时,具有最高优先级的元素最先删除。优先队列具有最高级先出的行为特征。我们来说一下C++的STL queue库中优先队列的使用方法。STL默认使用<操作符来确定对象之间的优先级关系,所以如果要使用自定义对象,需要重载<操作符。优先队列有两种,一种是最大优先队列;一种是最小优先队列;每次取自队列的第一个元素分别是优先级最大和优先级最小的元素。

使用头文件queue。

优先队列的操作:

q.empty() 判断是否为空

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

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

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

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

默认优先级为最大优先,除此之外共有3种自定义优先级方式。

 #include <iostream>
#include <functional>
#include <queue>
#include <vector> using namespace std; struct cmp1//定义比较结构
{
bool operator ()(int &a,int &b)
{
return a>b;//最小值优先
}
}; struct cmp2
{
bool operator ()(int &a,int &b)
{
return a<b;//最大值优先
}
}; struct number1//自定义数据结构
{
int x; bool operator < (const number1 &a) const
{
return x>a.x;//最小值优先
}
}; struct number2
{
int x; bool operator < (const number2 &a) const
{
return x<a.x;//最大值优先
}
}; int main()
{
int n;
cin>>n;
int a[];
number1 num1[];
number2 num2[];
for(int i=;i<n;i++)
{
cin>>a[i];
num1[i].x=a[i];
num2[i].x=a[i];
}
cout<<endl;
priority_queue<int>Q0;//采用默认优先级构造队列
priority_queue<int,vector<int>,cmp1>Q1;//最小值优先
priority_queue<int,vector<int>,cmp2>Q2;//最大值优先
priority_queue<int,vector<int>,greater<int> >Q3;//一定要有空格“> >”,“>>”会被认为错误
priority_queue<int,vector<int>,less<int> >Q4;////最大值优先
priority_queue<number1>Q5; //最小优先级队列
priority_queue<number2>Q6; //最大优先级队列
int i;
for(i=; i<n; i++)
{
Q0.push(a[i]);
Q1.push(a[i]);
Q2.push(a[i]);
Q3.push(a[i]);
Q4.push(a[i]);
}
for(i=; i<n; i++)
Q5.push(num1[i]);
for(i=; i<n; i++)
Q6.push(num2[i]);
//采用默认优先关系 (priority_queue<int>que)
cout<<"Queue0:"<<endl;
while(!Q0.empty())
{
cout<<Q0.top()<<" ";
Q0.pop();
}
cout<<endl<<endl;
//采用结构体自定义优先级方式一 (priority_queue<int,vector<int>,cmp>que)
cout<<"Queue1:"<<endl;
while(!Q1.empty())
{
cout<<Q1.top()<<" ";
Q1.pop();
}
cout<<endl;
cout<<"Queue2:"<<endl;
while(!Q2.empty())
{
cout<<Q2.top()<<" ";
Q2.pop();
}
cout<<endl<<endl;
//采用头文件functional内定义优先级 (priority_queue<int,vector<int>,greater<int>/less<int> >que)
cout<<"Queue3:"<<endl;
while(!Q3.empty())
{
cout<<Q3.top()<<" ";
Q3.pop();
}
cout<<endl;
cout<<"Queue4:"<<endl;
while(!Q4.empty())
{
cout<<Q4.top()<<" ";
Q4.pop();
}
cout<<endl<<endl;
//采用结构体自定义优先级方式二 (priority_queue<number>que)
cout<<"Queue5:"<<endl;
while(!Q5.empty())
{
cout<<Q5.top().x<<" ";
Q5.pop();
}
cout<<endl;
cout<<"Queue6:"<<endl;
while(!Q6.empty())
{
cout<<Q6.top().x<<" ";
Q6.pop();
}
cout<<endl;
return ;
}

运行结果:

STL中优先队列的使用的更多相关文章

  1. STL之优先队列

    STL 中优先队列的使用方法(priority_queu) 基本操作: empty() 如果队列为空返回真 pop() 删除对顶元素 push() 加入一个元素 size() 返回优先队列中拥有的元素 ...

  2. STL中队列(queue)的使用方法

    STL 中队列的使用(queue) 基本操作: push(x) 将x压入队列的末端 pop() 弹出队列的第一个元素(队顶元素),注意此函数并不返回任何值 front() 返回第一个元素(队顶元素) ...

  3. 手写队列以及stl中队列的使用

    一,手写队列. struct queue { ; ,rear=,a[maxn]; void push(int x) { a[++rear]=x; } void pop() { first++; } i ...

  4. 浅谈C++ STL中的优先队列(priority_queue)

    从我以前的博文能看出来,我是一个队列爱好者,很多并不是一定需要用队列实现的算法我也会采用队列实现,主要是由于队列和人的直觉思维的一致性导致的. 今天讲一讲优先队列(priority_queue),实际 ...

  5. STL中heap相关函数

    heap并不是属于STL中的containers,而是在<algorithm>下提供了相关的函数 make_heap,sort_heap,pop_heap,push_heap 函数的说明: ...

  6. STL中sort、priority_queue、map、set的自定义比较函数

    STL中,sort的默认排序为less,也就是说从小到大排序:priority_queue默认是less,也就说大顶堆:map默认是less,也就说用迭代器迭代的时候默认是小的排在前面:set默认是l ...

  7. STL中六大组件

    1)容器(Container),是一种数据结构,如list,vector,和deques ,以模板类的方法提供.为了访问容器中的数据,可以使用由容器类输出的迭代器: 容器(container)用于存放 ...

  8. C++ 队列!还是要从 STL 中的说起……

    1. 前言 队列和栈一样,都是受限的数据结构. 队列遵循先进先出的存储原则,类似于一根水管,水从一端进入,再从另一端出去.进入的一端称为队尾,出去的一端称为队头. 队列有 2 个常规操作: 入队:进入 ...

  9. STL中的set容器的一点总结

    1.关于set C++ STL 之所以得到广泛的赞誉,也被很多人使用,不只是提供了像vector, string, list等方便的容器,更重要的是STL封装了许多复杂的数据结构算法和大量常用数据结构 ...

随机推荐

  1. PHP 文件加密Zend Guard Loader 学习和使用(如何安装ioncube扩展对PHP代码加密)

    一.大体流程图 二.PHP 项目文件加密 下表列出了Zend产品中的PHP版本及其内部API版本和Zend产品版本. 如何加密请往后看 三.如何使用 第一步:确认当前环境 Amai Phalcon 前 ...

  2. css框架,一把锋利的剑

    CSS 框架是一系列 CSS 文件的集合体,包含了基本的元素重置,页面排版.网格布局.表单样式.通用规则等代码块,用于简化web前端开发的工作,提高工作效率. 产生原因 互联网行业已经发展了多年,浏览 ...

  3. oracle用户密码过期!the password has expired

    Oracle提示错误消息ORA-28001: the password has expired,是由于Oracle11G的新特性所致, Oracle11G创建用户时缺省密码过期限制是180天(即6个月 ...

  4. A - Jugs ZOJ - 1005 (模拟)

    题目链接:https://cn.vjudge.net/contest/281037#problem/A 题目大意:给你a,b,n.a代表第一个杯子的容量,b代表第二个杯子的容量,然后一共有6种操作.让 ...

  5. 2017-2018-2 20165227 实验四《Android程序设计》实验报告

    一.实验报告封面 课程: Java程序设计 班级: 1652班 姓名: 朱越 学号: 20165227 指导教师: 娄嘉鹏 实验日期: 2018年5月14日 实验时间: 13:45 - 3:25 实验 ...

  6. js实现避免浏览器拦截弹出新页面的方法

    1 问题描述 点击button按钮,提交页面的form表单,后台执行完毕后返回参数,前台页面需要该参数实现跳转,如何实现保留该原来的页面,并在浏览器选项卡新建一个页面,且不被浏览器拦截? 2 方法及问 ...

  7. Wiggle Sort I & II

    Given an unsorted array nums, reorder it in-place such that nums[0] <= nums[1] >= nums[2] < ...

  8. 001_关于选中的磁盘具有MBR分区表。在 EFI 系统上,Windows 只能安装到 GPT 磁盘。问题解决

    问题: 今天我的diy电脑重装系统时,遇到了一个棘手的问题.在选择安装分区的时候,提示有这样的错误. Windows 无法安装到这个磁盘.选中的磁盘具有MBR分区表.在 EFI 系统上,Windows ...

  9. MVC5使用EF6 Code First--创建EF数据模型(一)

    此Web应用程序演示如何使用Entity Framework 6和Visual Studio 2015创建ASP.NET MVC 5应用程序.本教程使用“Code First ”即代码先行.有关如何在 ...

  10. Ibatis.Net 表连接查询学习(五)

    IBatis.Net之多表查询 一.定制实际对应类的方式 首先配置多表的测试数据库,在之前Person表中增加一列"CountryId",新建一张Country表,两张表关系如下: ...