优先队列 小结
程序员文章站
2022-03-05 23:50:49
...
目录
一.优先队列概念
了解完队列之后我们来了解一种特殊的队列--优先队列
优先队列是一种特殊的队列,相较于队列它的特殊也是功能最强大之处在于能自动排序。
二.优先队列的头文件
#include<queue>
using namespace std; //命名空间不是头文件
三.优先队列的声明
优先队列声明的基本格式是:
priority_queue<结构类型> 队列名;
例:
priority_queue <int> p;
priority_queue <double> p;
然而最常用的是以下几种
priority_queue <node> p;
//node是一个结构体
//结构体里重载了‘<’小于符号
priority_queue <int,vector<int>,greater<int> > p;
//不需要#include<vector>头文件
//注意后面两个“>”不要写在一起,“>>”是右移运算符
priority_queue <int,vector<int>,less<int> >p;
四.优先队列的基本操作
与队列的操作基本一致
例.queue<int> q;
1.入队 q.push();
2.出队 q.pop();
3.求队列中元素个数 q.size();
4.判断度列是否为空 q.empty();若为空返回true,否则返回false
5.获得首元素 q.top();
6.返回q的第一个元素 q.top();
7.返回q的末尾元素 q.back();
五.优先队列的排序
默认的优先队列 priority_queue <int> q;排序是由大到小的,代码为证
#include<stdio.h>
#include<queue>
using namespace std;
int main()
{
priority_queue<int> q;
int num[5]={19,2,4,3,6};
for(int i=0;i<5;i++)
q.push(num[i]);
for(int i=0;i<5;i++)
{
int temp=q.top();
printf("%d ",temp);
q.pop();
}
return 0;
}
输出结果为
默认的优先队列(结构体,重载小于)
#include<stdio.h>
#include<queue>
using namespace std;
struct node
{
int x,y;
bool operator < (const node & a) const
{
return x<a.x;
}
}s;
priority_queue <node> q;
int main()
{
printf("读入:\n");
for(int i=0;i<5;i++)
{
scanf("%d%d",&s.x,&s.y);
q.push(s);
}
printf("输出:\n");
while(!q.empty())
{
node temp=q.top();
printf("(%d,%d) ",temp.x,temp.y);
q.pop();
}
return 0;
}
输入和输出结果:
接下来是less和greater优先队列
以int为例,先声明:
priority_queue <int,vector<int>,less<int> > p;
priority_queue <int,vector<int>,greater<int> > q;
#include<stdio.h>
#include<queue>
using namespace std;
int main()
{
priority_queue <int,vector<int>,less<int> > p;
priority_queue <int,vector<int>,greater<int> > q;
int num[5]={10,12,14,6,8};
for(int i=0;i<5;i++)
{
p.push(num[i]);
q.push(num[i]);
}
printf("less<int>:");
while(!p.empty())
{
int temp=p.top();
printf("%d ",temp);
p.pop();
}
printf("\n");
printf("greater<int>:");
while(!q.empty())
{
int temp=q.top();
printf("%d ",temp);
q.pop();
}
return 0;
}
输出结果为:
由此可见
less是从大到小,greater是从小到大
上一篇: 递归 队列 优先队列笔记
下一篇: 机器学习之决策树