当前位置: 首页 > news >正文

【STL】priority_queue 基础,应用与操作

c在C++的标准模板库(STL)中,priority_queue 是一个基于堆的容器适配器,用于实现优先级队列。它本质上是一个最大堆(Max-Heap),即每次取出元素时,始终取出优先级最高的元素。本文将详细讲解priority_queue的基础操作、特性及使用注意事项。

1. priority_queue的基本概念

priority_queue 是一个容器适配器,通常底层使用 vector 和堆(默认是最大堆)来实现。队列中元素按照优先级排序,默认情况下,优先级最高的元素会被优先弹出。这意味着,容器中第一个元素始终是值最大的。

1.1 头文件

要使用 priority_queue,必须包含头文件:

#include <queue>

1.2 基本定义

std::priority_queue<int> pq;  // 定义一个存储 int 类型的优先级队列(默认最大堆)

1.3 底层容器选择

priority_queue 可以选择不同的底层容器,常用的包括 vector 和 deque,默认情况下是使用 vector。

2. priority_queue 的基本操作

2.1 push() 插入元素

使用 push() 向队列中插入新元素。插入时,元素会根据优先级被放置到合适的位置。

pq.push(5);   // 插入元素 5
pq.push(10);  // 插入元素 10
pq.push(3);   // 插入元素 3

在插入后,priority_queue 会自动调整,使得最大元素始终位于队列顶端。

2.2 top() 获取最大元素

使用 top() 来访问队列中优先级最高的元素(即最大元素)。这个操作不会移除元素,只是返回它的值。

std::cout << pq.top();  // 输出 10

2.3 pop() 移除最大元素

使用 pop() 来移除队列中优先级最高的元素。请注意,这个操作并不返回被移除的元素,仅仅是将其从队列中删除。

pq.pop();  // 移除优先级最高的元素(10)

2.4 empty() 检查队列是否为空

使用 empty() 可以检查优先级队列是否为空,返回一个布尔值。

if (pq.empty()) 
{std::cout << "Queue is empty." << std::endl;
}

2.5 size() 返回队列的元素个数

使用 size() 可以返回当前队列中元素的个数。

std::cout << pq.size();  // 输出当前队列中元素的个数

3. 自定义比较函数(最小堆)

默认情况下,priority_queue 是一个最大堆,但可以通过自定义比较器将其变为最小堆。通过指定比较函数,可以改变元素的排列顺序。

3.1 使用 greater 实现最小堆

可以使用 std::greater 来使得 priority_queue 变为最小堆,即优先级最低的元素会优先弹出。

#include <functional>  // 引入 less 和 greaterstd::priority_queue<int, std::vector<int>, std::greater<int>> minHeap;

4. priority_queue 特性与注意事项

4.1 底层实现机制

priority_queue 的底层实现依赖于堆排序算法,因此其时间复杂度如下:

  • 插入操作 push():O(log n)
  • 获取最大元素 top():O(1)
  • 删除最大元素 pop():O(log n)

4.2 避免直接遍历

priority_queue 并不提供直接遍历所有元素的方法,原因是它的结构是基于堆的,内部顺序并不保证元素是按优先级依次排列的。因此,如果需要遍历所有元素,通常需要借助额外的容器或将元素逐个弹出。

4.3 谨慎修改元素

priority_queue 并不支持直接修改元素的优先级,一旦插入某个元素,想要调整优先级只能将该元素删除后,重新插入带有新优先级的元素。

5. 使用场景

priority_queue 适用于那些需要频繁取出优先级最高(或最低)元素的场景。常见的应用场景包括:

  • 任务调度:根据任务的优先级决定执行顺序。
  • 图算法:如Dijkstra算法和Prim算法,利用优先级队列高效处理最短路径或最小生成树。
  • 数据流处理:实时处理数据流中前 k 大或前 k 小的元素。

实例如下:

以下是一个简单的例子,演示了如何使用 priority_queue 来处理最大堆和最小堆。

#include <iostream>
#include <queue>
#include <vector>
using namespace std;int main()
{// 默认最大堆priority_queue<int> maxHeap;maxHeap.push(3);maxHeap.push(5);maxHeap.push(1);cout << "Max-Heap: ";while (!maxHeap.empty()){cout << maxHeap.top() << " ";  // 输出 5 3 1maxHeap.pop();}cout << endl;// 最小堆priority_queue<int, vector<int>, greater<int>> minHeap;minHeap.push(3);minHeap.push(5);minHeap.push(1);cout << "Min-Heap: ";while (!minHeap.empty()){cout << minHeap.top() << " ";  // 输出 1 3 5minHeap.pop();}return 0;
}

在这里插入图片描述

7. 总结

priority_queue 是C++ STL中一个强大的容器适配器,用于处理需要频繁访问优先级最高(或最低)元素的场景。 通过了解其基本操作、自定义排序规则以及底层实现机制,开发者可以更加灵活地应用它来解决各类优先级相关的问题。不过,也要注意其一些限制,如无法直接遍历和修改元素优先级。

相关文章:

【STL】priority_queue 基础,应用与操作

c在C的标准模板库&#xff08;STL&#xff09;中&#xff0c;priority_queue 是一个基于堆的容器适配器&#xff0c;用于实现优先级队列。它本质上是一个最大堆&#xff08;Max-Heap&#xff09;&#xff0c;即每次取出元素时&#xff0c;始终取出优先级最高的元素。本文将详细…...

tasklist命令的应用实例

tasklist命令的应用实例 引言 在系统管理和故障排查过程中&#xff0c;了解当前正在运行的进程信息是至关重要的。Windows操作系统提供了一个强大的命令行工具——tasklist&#xff0c;它可以帮助用户查看当前系统中所有正在运行的进程及其相关信息。掌握这个命令的使用&…...

基于协同过滤算法+PHP的新闻推荐系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 【2025最新】基于协同过滤算法PHPMySQL的新…...

196页满分PPT | 集团流程优化及IT规划项目案例

细阐述了XX集团信息化建设的总体目标、指导原则、信息架构规划、应用系统架构规划、IT基础设施架构规划以及IT管控模式设计。文档内容涵盖了从现状分析到未来三年信息化建设目标的明确&#xff0c;以及如何通过IT系统支持集团的战略升级。 背景痛点 总体信息架构规划 总体信息架…...

Android 使用高德地图实现道格拉斯 - 普克算法

道格拉斯 - 普克算法&#xff08;Douglas-Peucker algorithm&#xff09;是一种用于曲线简化的算法。 一、算法的作用 该算法的主要目的是在保持曲线形状特征的前提下&#xff0c;通过减少数据点的数量来简化曲线。这在地图绘制、图形处理、地理信息系统等领域有广泛的应用。例…...

OpenAI GPT o1技术报告阅读(2)- 关于模型安全性的测试案例

✨报告阅读&#xff1a;使用大模型来学习推理(Reason) 首先是原文链接&#xff1a;https://openai.com/index/learning-to-reason-with-llms/ 接下来我们看一个简单的关于模型安全性的测试&#xff0c;当模型被问到一个有风险的话题时&#xff0c;会如何思考并回答用户呢&…...

Stream流的思想和获取Stream流

首先介绍流的概念&#xff1a; 流可以理解为一条流水线&#xff0c;在这条流水线中有许多操作&#xff0c;比如筛选所需要的数据&#xff0c;输出打印等&#xff0c; 经过这条流水线&#xff0c;可以获取到自己所需要的数据&#xff1a; -->所以&#xff1a; Stream流的作…...

go语言中的切片详解

1.概念 在Go语言中&#xff0c;切片&#xff08;Slice&#xff09;是一种基于数组的更高级的数据结构&#xff0c;它提供了一种灵活、动态的方式来处理序列数据。切片在Go中非常常用&#xff0c;因为它们可以动态地增长和缩小&#xff0c;这使得它们比固定大小的数组更加灵活。…...

ElK 8 收集 Nginx 日志

1. 说明 elk 版本&#xff1a;8.15.0 2. 启个 nginx 有 nginx 可以直接使用。我这里是在之前环境下 docker-compose.yml 中启动了个 nginx&#xff1a; nginx:restart: alwaysimage: nginx:1.26.1ports:- "80:80"- "443:443"volumes:#- ./nginx/html:/…...

Xv6驱动(四):CLINT

阅读材料 Xv6代码&#xff1a;memlayout.h、start.c、kernelvec.S教材5.4节 CLINT内存映射 实际上&#xff0c;CLINT还包括若干个MSIP寄存器&#xff0c;用来触发软件中断&#xff0c;但是在Xv6中不考虑软件中断&#xff0c;因此这些寄存器也不用考虑 // core local interr…...

【LInux】HTTPS是如何实现安全传输的

1. 客户端发起HTTPS连接请求 当浏览器请求一个HTTPS网址时&#xff0c;客户端&#xff08;例如浏览器&#xff09;会向服务器发起一个HTTPS请求。 2. 服务器返回数字证书 服务器收到请求后&#xff0c;会向客户端发送包含公钥的数字证书。数字证书由**权威认证机构&#xff…...

英飞凌PSoC4000T的GPIO中断示例工程

关于PSoC4000T的初步介绍见:英飞凌MCU第五代高性能CAPSENSE技术PSoC4000T_psoc 4000t-CSDN博客 下面这个工程,在modustoolbox中可编译、下载到开发板、debug调试。 编译时会用到mtb_shared这个库: 已经pdl这个periperal driver library库:...

物联网(IoT)中基于深度学习的入侵检测系统的综合综述

这篇论文是一篇全面的综述&#xff0c;标题为“A comprehensive survey on deep learning-based intrusion detection systems in Internet of Things (IoT)”&#xff0c;作者是Qasem Abu Al-Haija和Ayat Droos。论文主要探讨了在物联网(IoT)环境中基于深度学习的入侵检测系统…...

《成都体育学院学报》

投稿指南 成都体育学院学报属于体育类型期刊&#xff0c;由成都体育学院主办&#xff0c;国内统一刊号&#xff1a;51-1097/G8&#xff0c;国际标准刊号&#xff1a;1001-9154&#xff0c;双月&#xff0c;面向国内外公开发行。 一、来稿必须是作者独立取得的原创性学术研究成…...

Flask-JWT-Extended登录验证, 不用自定义

"""安装:pip install Flask-JWT-Extended创建对象 初始化与app绑定jwt JWTManager(app) # 初始化JWTManager设置 Cookie 的选项:除了设置 cookie 的名称和值之外&#xff0c;你还可以指定其他的选项&#xff0c;例如&#xff1a;过期时间 (max_age)&#xff1…...

rpm 与 yum

11 rpm -qa | grep openssh rpm与 yum CentOS仅删除软件包本身而不删除依赖 https://blog.csdn.net/kangshuaibi/article/details/125472204...

几种修改docker默认存储位置的方法

需求 docker容器存放目录磁盘空间满了&#xff0c;需要转移数据&#xff0c;修改Docker默认存储位置 解决方法 方法&#xff11;&#xff1a;迁移到新目录 停止docker服务。 1systemctl stop docker; //每个liunx版本的命令不一样。创建新的docker目录&#xff0c;执行命令df…...

istio中如何使用serviceentry引入外部服务

假设需要引入一个外部服务&#xff0c;外部服务ip为10.10.102.90&#xff0c;端口为32033. 引入到istio中后&#xff0c;我想通过域名gindemo.test.ch:9090来访问这个服务。 serviceentry yaml内容如下&#xff1a; apiVersion: networking.istio.io/v1beta1 kind: ServiceEn…...

模仿抖音用户ID加密ID的算法MB4E,提高自己平台ID安全性

先看抖音的格式 对ID加密的格式 MB4EENgLILJPeQKhJht-rjcc6y0ECMk_RGTceg6JBAA 需求是 同一个ID 比如 413884936367560 每次获取得到的加密ID都是不同的&#xff0c;最终解密的ID都是413884936367560 注意这是一个加密后可解密原文的方式&#xff0c;不是单向加密 那么如下进行…...

solidwork镜像实体

效果如下&#xff1a; 可以看到这两条线是对称的。 第一步&#xff0c;点击这条要镜像的边&#xff0c;接着点击镜像实体。 然后选择镜像轴&#xff0c;即可...

面试-并行前缀和优化 Linear Attention

1 什么是前缀和? 定义: 第 k 个元素的状态依赖于第 k-1 个元素; 公式: 前缀和 = 从第 1 个,一直加到当前位置; 例子: 比如有 4 个数: A、B、C、D; 那么前缀和的结果为: S1 = A S2 = A + B S3 = A + B + C S4 = A + B + C + D在 Linear Attention 中有所体现,即,…...

华硕笔记本合盖不休眠解决方案:GHelper智能模式完全指南

华硕笔记本合盖不休眠解决方案&#xff1a;GHelper智能模式完全指南 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Strix, …...

实战应用:用快马生成生产级服务器巡检与故障排查工具,告别xshell单点操作

最近在团队里负责服务器运维工作&#xff0c;经常需要处理各种突发故障。每次打开xshell手动敲命令排查问题&#xff0c;不仅效率低&#xff0c;还容易遗漏关键检查项。于是我用InsCode(快马)平台开发了一个自动化巡检工具&#xff0c;彻底告别了单点操作的时代。分享下这个实战…...

3大突破!自动化资源管理工具重塑数字资产管控模式

3大突破&#xff01;自动化资源管理工具重塑数字资产管控模式 【免费下载链接】Onekey Onekey Steam Depot Manifest Downloader 项目地址: https://gitcode.com/gh_mirrors/one/Onekey 一、问题定位&#xff1a;数字时代的资源管理困境 1.1 医疗机构&#xff1a;影像资…...

Odoo 19 AI功能实战:不用写代码,用自然语言就能自动化你的业务流程

Odoo 19 AI功能实战&#xff1a;不用写代码&#xff0c;用自然语言就能自动化你的业务流程 想象一下&#xff0c;早晨打开电脑&#xff0c;你只需要对系统说"把昨天所有未处理的客户咨询按优先级排序&#xff0c;并生成回复草稿"&#xff0c;30秒后就能收到整理好的列…...

【从零开始学Java | 第二十九篇】数组工具类Arrays和集合工具类Collections

目录 前言 一、数组工具类Arrays 1.数组的打印 2.数组的排序和查找 3.数组的复制和扩容 4.数组转换集合 二、集合工具类Collections 1.排序和位置操作 2.查找和极值运算 前言 本次学习两个Java提供的工具类&#xff0c;第一个是用来操作数组的工具类——Arrays&#x…...

XGP-save-extractor:跨平台开源工具守护游戏存档数据安全

XGP-save-extractor&#xff1a;跨平台开源工具守护游戏存档数据安全 【免费下载链接】XGP-save-extractor Python script to extract savefiles out of Xbox Game Pass for PC games 项目地址: https://gitcode.com/gh_mirrors/xg/XGP-save-extractor 在游戏世界中&…...

华为FusionCompute存储虚拟化实战:VIMS心跳与分布式锁的5个关键配置细节

华为FusionCompute存储虚拟化实战&#xff1a;VIMS心跳与分布式锁的5个关键配置细节 在虚拟化环境中&#xff0c;存储系统的稳定性和性能直接影响整个云平台的可靠性。华为FusionCompute作为企业级虚拟化解决方案&#xff0c;其VIMS&#xff08;Virtual Infrastructure Manage…...

告别JSON臃肿!在STM32上用nanopb实现高效数据通信(附完整工程)

告别JSON臃肿&#xff01;在STM32上用nanopb实现高效数据通信&#xff08;附完整工程&#xff09; 在嵌入式开发领域&#xff0c;数据通信的效率往往决定着整个系统的性能上限。当你的STM32F103只有20KB RAM可用时&#xff0c;JSON这种看似方便的文本协议突然变成了奢侈的选择…...

解锁Sony相机潜能:PMCA-RE工具全方位技术指南

解锁Sony相机潜能&#xff1a;PMCA-RE工具全方位技术指南 【免费下载链接】Sony-PMCA-RE Reverse Engineering Sony Digital Cameras 项目地址: https://gitcode.com/gh_mirrors/so/Sony-PMCA-RE 副标题&#xff1a;探索相机底层控制与自定义应用开发的开源解决方案 第…...