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

C++ STL 中的 priority_queue::push() 和 priority_queue::pop()

        优先级队列是一种容器适配器,经过专门设计,队列的第一个元素要么是队列中所有元素中最大的,要么是最小的。然而,在 C++ STL 中(默认情况下),最大的元素位于顶部。我们还可以创建一个优先级队列,在创建优先级队列时只需传递一个额外的参数,将最小的元素放在顶部。

优先级队列::push()

        push() 函数用于在优先级队列中插入一个元素。该元素被添加到优先级队列容器中,队列的大小增加 1。首先,将元素添加到后面,同时优先级队列的元素根据优先级重新排序。 

时间复杂度:O(log n)
语法 :

pqueuename.push(value)
参数:
要插入的元素的值作为参数传递。
结果 :
添加与以下元素值相同的元素
优先级队列中传递的参数。

例子:
输入:pqueue 
         pqueue.push(6);
输出:6

输入:pqueue = 5, 2, 1 
         pqueue.push(3);
输出:5, 3, 2, 1

错误和异常
1. 如果传递的值与优先级队列类型不匹配,则显示错误。 
2. 如果参数不引发任何异常,则显示无异常引发保证。 

// CPP program to illustrate
// Implementation of push() function
#include <iostream>
#include <queue>
using namespace std;
 
int main()
{
    // Empty Queue
    priority_queue<int> pqueue;
    pqueue.push(3);
    pqueue.push(5);
    pqueue.push(1);
    pqueue.push(2);
    // Priority queue becomes 5, 3, 2, 1
 
    // Printing content of queue
    while (!pqueue.empty()) {
        cout << ' ' << pqueue.top();
        pqueue.pop();
    }
}

输出:

5 3 2 1

优先级队列::pop()

pop() 函数用于删除优先级队列的顶部元素。 

时间复杂度:O(log n)
语法 :

pqueuename.pop()
参数:
不传递任何参数。

结果:
移除
优先级队列的顶部元素

例子:

输入:pqueue = 3, 2, 1 
         myqueue.pop();
输出:2, 1

输入:pqueue = 5, 3, 2, 1 
         pqueue.pop();
输出:3, 2, 1

错误和异常
1. 如果传递了参数,则显示错误。 
2. 如果参数没有引发任何异常,则显示无异常引发保证。

// CPP program to illustrate
// Implementation of pop() function
#include <iostream>
#include <queue>
using namespace std;
 
int main()
{
    // Empty Priority Queue
    priority_queue<int> pqueue;
    pqueue.push(0);
    pqueue.push(1);
    pqueue.push(2);
    // queue becomes 2, 1, 0
 
    pqueue.pop();
    pqueue.pop();
    // queue becomes 0
 
    // Printing content of priority queue
    while (!pqueue.empty()) {
        cout << ' ' << pqueue.top();
        pqueue.pop();
    }
}


输出:

0

        应用:push() 和 pop()给定一些整数,将它们添加到优先级队列,并在不使用 size 函数的情况下找到优先级队列的大小。

输入:5、13、0、9、4
输出:5

算法
1. 将给定元素逐个推送到优先级队列容器中。 
2. 不断弹出优先级队列的元素,直到队列为空,并增加计数器变量。 
3. 打印计数器变量。

// CPP program to illustrate
// Application of push() and pop() function
#include <iostream>
#include <queue>
using namespace std;
 
int main()
{
    int c = 0;
    // Empty Priority Queue
    priority_queue<int> pqueue;
    pqueue.push(5);
    pqueue.push(13);
    pqueue.push(0);
    pqueue.push(9);
    pqueue.push(4);
    // Priority queue becomes 13, 9, 5, 4, 0
 
    // Counting number of elements in queue
    while (!pqueue.empty()) {
        pqueue.pop();
        c++;
    }
    cout << c;
}

输出:

5

相关文章:

  • stm32MP135裸机编程:启动流程分析
  • 假设Python脚本包含引用了大量的第三方库,如何打包成.exe文件,并且可以在没有环境的服务器下正常运行
  • vue-2 组件传值
  • Django学习(2)项目实战
  • React 18
  • ISO 19115-2:2019 第6章 获取和处理元数据
  • 【C++】STL中list的使用
  • powerdesigner各种字体设置
  • 深度解析:全流量分析与IP会话回溯在IT运维中的应用
  • matlab演示银河系转动动画
  • 进程概念(二)
  • pytest配置文件配置并通过allure生成报告
  • 使用difflib实现文件差异比较用html显示
  • Ansible离线部署 之 Zabbix
  • c语言基础篇C
  • ➹使用webpack配置多页面应用(MPA)
  • ES6 ...操作符
  • express如何解决request entity too large问题
  • LeetCode541. Reverse String II -- 按步长反转字符串
  • Lucene解析 - 基本概念
  • MySQL几个简单SQL的优化
  • Vim 折腾记
  • vue-loader 源码解析系列之 selector
  • Vue全家桶实现一个Web App
  • 可能是历史上最全的CC0版权可以免费商用的图片网站
  • 那些被忽略的 JavaScript 数组方法细节
  • 如何编写一个可升级的智能合约
  • 数组大概知多少
  • Play Store发现SimBad恶意软件,1.5亿Android用户成受害者 ...
  • ​Redis 实现计数器和限速器的
  • ​sqlite3 --- SQLite 数据库 DB-API 2.0 接口模块​
  • ​总结MySQL 的一些知识点:MySQL 选择数据库​
  • # 利刃出鞘_Tomcat 核心原理解析(七)
  • #QT项目实战(天气预报)
  • #数学建模# 线性规划问题的Matlab求解
  • (4)STL算法之比较
  • (C#)一个最简单的链表类
  • (Oracle)SQL优化基础(三):看懂执行计划顺序
  • (WSI分类)WSI分类文献小综述 2024
  • (八)Docker网络跨主机通讯vxlan和vlan
  • (附源码)计算机毕业设计SSM保险客户管理系统
  • (个人笔记质量不佳)SQL 左连接、右连接、内连接的区别
  • (六)库存超卖案例实战——使用mysql分布式锁解决“超卖”问题
  • (全注解开发)学习Spring-MVC的第三天
  • (十三)Flink SQL
  • (学习日记)2024.04.10:UCOSIII第三十八节:事件实验
  • (一)SpringBoot3---尚硅谷总结
  • (转载)Google Chrome调试JS
  • (转载)虚函数剖析
  • .NET C# 使用 iText 生成PDF
  • .NET Micro Framework初体验
  • .net web项目 调用webService
  • .vimrc php,修改home目录下的.vimrc文件,vim配置php高亮显示
  • @Autowired标签与 @Resource标签 的区别
  • @RequestBody与@ResponseBody的使用