【C++】priority_queue优先队列

头文件#include <queue>

优先队列具有队列的所有特性,本质是一个堆实现的,和队列基本操作相同:

top 访问队头元素

empty 队列是否为空

size 返回队列内元素个数

push 插入元素到队尾 (并排序)

emplace 原地构造一个元素并插入队列

pop 弹出队头元素

swap 交换内容

和队列不一样的是,优先队列没有 front() 函数与 back() 函数,而只能通过 top() 函数来访问队首元素(也可以称为堆顶元素),也就是优先级最高的元素。

定义方式有两种

  1. typename 可以是任意基本数据类型或容器:

    priority_queue< typename > name;

  2. 定义:priority_queue<Type, Container, Functional>
    Type 数据类型,Container 容器类型(Container必须是用数组实现的容器,比如vector,deque等等,但不能用 list。STL里面默认用的是vector),Functional 就是比较的方式,当需要用自定义的数据类型时才需要传入这三个参数,使用基本数据类型时,只需要传入数据类型,默认是大顶堆。
    注意第二个参数填写的是来承载底层数据结构堆(heap)的容器,如果第一个参数是 double 型或 char 型,则此处只需要填写 vector 或 vector;
    而第三个参数 则是对第一个参数的比较类,less 表示数字大的优先级越大,而 greater 表示数字小的优先级越大。也可以自定义数据比较关系

对基本数据类型来说,下面两种优先队列的定义是等价的(以 int 型为例,注意最后两个 > 之间有一个空格):

复制代码
priority_queue<int> q;
priority_queue<int,vector<int>,less<int>> q;

如果想让优先队列总是把最小的元素放在队首,则需进行如下定义:

复制代码
priority_queue<int,vector<int>,greater<int>>q;

如果不是基本类型,那么结构体的优先级设置方法有所区别需要重载小于号"<" 例如

复制代码
struct student
{
    string name;
    int age;
    friend bool operator <(student s1,student s2)
    {
        return student.age <student.age;
    }
};

重载大于号会编译错误,因为从数学上来说只需要重载小于号,即 f1 > f2 等价于判断 f2 < f1,而 f1 == f2 则等价于判断!(f1<f2) &&!(f2<fl))

如果想把重载写在变量结构体外面则需要重载小括号()同时将其用struct包装起来,例如

复制代码
struct ListNode {
    int val;
    ListNode *next;
    ListNode() : val(0), next(nullptr) {}
    ListNode(int x) : val(x), next(nullptr) {}
    ListNode(int x, ListNode *next) : val(x), next(next) {}
}
struct comp{
    bool operator() (ListNode *L1,ListNode *L2){
        return L1->val > L2->val;
    }
};
priority_queue<ListNode*,vector<ListNode*>,comp> q;
相关推荐
草莓熊Lotso1 小时前
【Linux系统加餐】从原理到封装:基于建造者模式实现System V信号量工业级C++封装
android·linux·运维·服务器·网络·c++·建造者模式
潜创微科技7 小时前
IT6520:USB‑C 转 MIPI 芯片方案 4K@120Hz 高清显示
c语言·开发语言
言之。8 小时前
【Python】免费的中文 AI 配音方案
开发语言·人工智能·python
kyle~8 小时前
机器视觉---熔池相机(穿透强光的视觉感知)
c++·数码相机·计算机视觉·机器人·焊接机器人
宏笋8 小时前
C++ Coroutines(协程) 详解
c++
天天进步20158 小时前
Python全栈项目:从零手操一个高性能 API 网关
开发语言·python
Java面试题总结8 小时前
java高频面试题(2026最新)
java·开发语言·jvm·数据库·spring·缓存
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之前缀和&差分 --【一维前缀和】:求区间和
c++·前缀和·csp·高频考点·信奥赛·求和区间和
kyle~9 小时前
机器人时间链路---工程流程示例
c++·3d·机器人·ros2
安生生申9 小时前
使用pygame实现2048
开发语言·python·pygame