0

0

c++中priority_queue怎么使用_priority_queue优先级队列用法详解

穿越時空

穿越時空

发布时间:2025-09-30 19:05:02

|

725人浏览过

|

来源于php中文网

原创

priority_queue是C++中基于堆的容器适配器,默认为大根堆,定义在queue头文件中,支持push、pop、top等操作;通过std::greater可实现小根堆;自定义类型需重载

c++中priority_queue怎么使用_priority_queue优先级队列用法详解

在C++中,priority_queue 是一个基于堆结构实现的容器适配器,用于自动维护元素的优先级顺序。默认情况下,它是一个大根堆,即队头始终是当前最大的元素。它定义在 queue 头文件中,使用非常方便,适用于需要动态管理优先级的场景,比如Dijkstra算法、合并K个有序链表等。

基本用法与定义

要使用 priority_queue,需包含头文件:

#include

最简单的定义方式如下:

std::priority_queue pq;

这创建了一个存储整数的大顶堆。插入和访问元素的方法如下:

立即学习C++免费学习笔记(深入)”;

  • pq.push(x):将元素 x 插入队列,自动调整堆结构。
  • pq.pop():移除堆顶(最大值),不返回值。
  • pq.top():返回堆顶元素(最大值)。
  • pq.empty():判断队列是否为空。
  • pq.size():返回元素个数。

示例代码:

std::priority_queue pq;
pq.push(10);
pq.push(30);
pq.push(20);
while (!pq.empty()) {
    std::cout     pq.pop();
}
// 输出:30 20 10

小根堆的实现

默认是大根堆,如果需要小根堆(最小值在顶部),可以通过指定比较函数来实现。常用方法是使用 std::greater

Clippah
Clippah

AI驱动的创意视频处理平台

下载
std::priority_queue, std::greater> min_pq;

此时插入相同数据:

min_pq.push(10);
min_pq.push(30);
min_pq.push(20);
while (!min_pq.empty()) {
    std::cout     min_pq.pop();
}
// 输出:10 20 30

注意模板参数顺序:

  • 第一个:元素类型(如 int)
  • 第二个:底层容器类型,默认是 vector,通常不需要改
  • 第三个:比较类,决定排序规则

自定义类型与比较规则

当处理结构体或类时,需要自定义比较逻辑。有两种常见方式:

方法一:重载操作符

struct Person {
    int age;
    std::string name;
    bool operator         return age     }
};
std::priority_queue pq;

方法二:传入仿函数或lambda(推荐用于复杂逻辑)

auto cmp = [](const Person& a, const Person& b) {
    return a.age };
std::priority_queue, decltype(cmp)> pq(cmp);

注意:这里需要把比较函数对象传给构造函数,否则会出错。

常见应用场景

1. 求前K大/小元素
用小根堆维护K个最大元素,遍历数组即可高效求解。

2. 合并K个有序链表
将每个链表头节点放入 priority_queue,每次取出最小节点,并将其 next 加入队列。

3. 贪心算法
如任务调度问题,总是选择当前最优任务执行。

4. 图算法中的Dijkstra
用优先队列代替普通队列,快速取出距离最短的未处理节点。

基本上就这些。priority_queue 使用简单,关键是理解其默认是大顶堆,要小顶堆就得手动指定 greater 或自定义比较方式。自定义类型时注意比较逻辑的写法,避免编译错误或逻辑颠倒。掌握好这个工具,能大幅提升编码效率。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

503

2023.08.02

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

98

2023.09.25

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

532

2023.09.20

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

282

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

192

2025.07.04

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

282

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

192

2025.07.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

503

2023.08.02

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

30

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Rust 教程
Rust 教程

共28课时 | 5.2万人学习

Git 教程
Git 教程

共21课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号