优先队列 小结

目录

一.优先队列概念

二.优先队列的头文件

三.优先队列的声明

四.优先队列的基本操作

五.优先队列的排序


一.优先队列概念

了解完队列之后我们来了解一种特殊的队列--优先队列

优先队列是一种特殊的队列,相较于队列它的特殊也是功能最强大之处在于能自动排序。

二.优先队列的头文件

#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是从小到大

  • 5
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值