前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【C++】STL 容器 - priority_queue 优先级队列容器 ( 容器简介 | 容器操作性能分析 | 默认优先级队列容器 | 最大值优先级队列 | 最小值优先级队列 )

【C++】STL 容器 - priority_queue 优先级队列容器 ( 容器简介 | 容器操作性能分析 | 默认优先级队列容器 | 最大值优先级队列 | 最小值优先级队列 )

作者头像
韩曙亮
发布2023-12-27 08:53:48
1350
发布2023-12-27 08:53:48
举报

一、priority_queue 优先级队列容器

1、priority_queue 优先级队列容器简介

容器简介 : priority_queue 优先级队列容器 是一种数据结构 , 可以 存储元素并根据优先级进行访问 ;

容器元素顺序排列 : priority_queue 优先级队列容器 中的 元素顺序 , 是根据 优先级 决定的 , 优先级 最高的元素 , 位于 队列的 顶部 / 首部 / 队头 位置 ;

容器元素自动排序 : priority_queue 优先级队列容器 会对元素 进行自动排序 , 确保 优先级最高的 元素 , 在队首位置 ;

优先级比较函数 : 对 元素 进行优先级排序 需要一个 比较函数 , 系统根据元素类型 默认指定了一个比较函数 ; 开发者也可以根据自己的需求 , 自定义比较函数 ;

底层容器选择 : priority_queue 优先级队列容器 可以 与任何满足特定需求的底层容器结合使用 , 如 : vector 动态数组容器 , deque 双端数组容器 , list 双向链表容器 ;

导入的头文件 : 使用 priority_queue 优先级队列容器 之前 , 需要 导入 <queue> 头文件 ;

代码语言:javascript
复制
#include <queue>  

2、priority_queue 优先级队列容器操作性能分析

priority_queue 优先级队列容器操作性能分析 :

  • 调用 top 函数访问顶部元素 : 时间复杂度是 O(1) , 无论 容器中有多少元素 , 访问顶部元素只需要直接取出访问即可 ;
  • 调用 pop 函数删除顶部元素 : 时间复杂度是 O(1) , 直接将 顶部元素 删除即可 , 下一个元素自动称为新的顶部元素 ;
  • 调用 empty 函数判断容器是否为空 : 时间复杂度是 O(1) , 与 访问顶部元素 时间复杂度是一样的 , 只需要查看是否存在顶部元素即可 , 存在则不为空 , 不存在则为空 ;
  • 调用 push 函数向容器中插入元素 : 时间复杂度是 O(log n) , 插入元素时 , 一开始元素在队尾 , 需要进行上浮操作 , 将其放置在正确的位置 ; 容器默认的数据结构是堆 , 也就是 完全二叉树 , 其排序上浮的时间复杂度是 O(log n) ;

二、代码示例 - priority_queue 优先级队列容器

1、默认优先级队列容器

使用 如下代码 , 定义的 优先级队列容器 是 " 最大值优先级队列 " , 调用 top() 函数获取的队头首元素是最大值 ;

代码语言:javascript
复制
priority_queue<int> p;

优先级队列的 api 操作与 queue 类似 ;

  • 调用 push 函数 , 可以向容器中加入元素 , 加入时会自动排序放到合适位置 ;
  • 调用 pop 函数 , 可以将 队头元素 移除队列 ;
  • 调用 top 函数 , 可以获取 首元素 ;
  • 调用 size 函数 , 可以获取 容器大小 ;

代码示例 :

代码语言:javascript
复制
#include "iostream"
using namespace std;
#include "queue"

int main() {

	// 默认优先级队列 
	// 最大值优先级队列 首部元素是最大值
	priority_queue<int> p;

	// 向优先级队列容器中加入元素
	p.push(3);
	p.push(1);
	p.push(5);
	p.push(2);

	// 获取队头元素
	cout << "首元素 : " << p.top() << endl;

	// 获取容器大小
	cout << "容器大小 : " << p.size() << endl;

	// 容器元素内容遍历
	cout << "容器元素 : ";
	while (p.size() > 0)
	{
		// 获取首元素
		cout << p.top() << " ";
		// 首元素出队
		p.pop();
	}
	// 回车换行
	cout << endl;


	// 控制台暂停 , 按任意键继续向后执行
	system("pause");

	return 0;
};

执行结果 :

代码语言:javascript
复制
首元素 : 5
容器大小 : 4
容器元素 : 5 3 2 1
Press any key to continue . . .
在这里插入图片描述
在这里插入图片描述

2、最大值优先级队列

使用 如下代码 , 手动定义 " 最大值优先级队列 " , 下面的队列效果与 priority_queue<int> p 是一样的 ;

代码语言:javascript
复制
priority_queue<int , vector<int>, less<int>> p;

代码示例 :

代码语言:javascript
复制
#include "iostream"
using namespace std;
#include "queue"

int main() {

	// 最大值优先级队列 
	// 最大值优先级队列 首部元素是最大值
	priority_queue<int, vector<int>, less<int>> p;

	// 向优先级队列容器中加入元素
	p.push(3);
	p.push(1);
	p.push(5);
	p.push(2);

	// 获取队头元素
	cout << "首元素 : " << p.top() << endl;

	// 获取容器大小
	cout << "容器大小 : " << p.size() << endl;

	// 容器元素内容遍历
	cout << "容器元素 : ";
	while (p.size() > 0)
	{
		// 获取首元素
		cout << p.top() << " ";
		// 首元素出队
		p.pop();
	}
	// 回车换行
	cout << endl;


	// 控制台暂停 , 按任意键继续向后执行
	system("pause");

	return 0;
};

执行结果 :

代码语言:javascript
复制
首元素 : 5
容器大小 : 4
容器元素 : 5 3 2 1
Press any key to continue . . .
在这里插入图片描述
在这里插入图片描述

3、最小值优先级队列

使用 如下代码 , 手动定义 " 最小值优先级队列 " , 下面的队列效果与 priority_queue<int> p 是一样的 ;

代码语言:javascript
复制
priority_queue<int , vector<int>, greater<int>> p;

代码示例 :

代码语言:javascript
复制
#include "iostream"
using namespace std;
#include "queue"

int main() {

	// 最小值优先级队列 
	// 最小值优先级队列 首部元素是最小值
	priority_queue<int, vector<int>, greater<int>> p;

	// 向优先级队列容器中加入元素
	p.push(3);
	p.push(1);
	p.push(5);
	p.push(2);

	// 获取队头元素
	cout << "首元素 : " << p.top() << endl;

	// 获取容器大小
	cout << "容器大小 : " << p.size() << endl;

	// 容器元素内容遍历
	cout << "容器元素 : ";
	while (p.size() > 0)
	{
		// 获取首元素
		cout << p.top() << " ";
		// 首元素出队
		p.pop();
	}
	// 回车换行
	cout << endl;


	// 控制台暂停 , 按任意键继续向后执行
	system("pause");

	return 0;
};

执行结果 :

代码语言:javascript
复制
首元素 : 1
容器大小 : 4
容器元素 : 1 2 3 5
Press any key to continue . . .
在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-12-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、priority_queue 优先级队列容器
    • 1、priority_queue 优先级队列容器简介
      • 2、priority_queue 优先级队列容器操作性能分析
      • 二、代码示例 - priority_queue 优先级队列容器
        • 1、默认优先级队列容器
          • 2、最大值优先级队列
            • 3、最小值优先级队列
            相关产品与服务
            容器服务
            腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档