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

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

时间:2024-01-02 12:05:37浏览次数:34  
标签:容器 优先级 队列 元素 queue priority



文章目录

  • 一、priority_queue 优先级队列容器
  • 1、priority_queue 优先级队列容器简介
  • 2、priority_queue 优先级队列容器操作性能分析
  • 二、代码示例 - priority_queue 优先级队列容器
  • 1、默认优先级队列容器
  • 2、最大值优先级队列
  • 3、最小值优先级队列








一、priority_queue 优先级队列容器



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



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



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

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

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

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



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

#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() 函数获取的队头首元素是最大值 ;

priority_queue<int> p;

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

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


代码示例 :

#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;
};

执行结果 :

首元素 : 5
容器大小 : 4
容器元素 : 5 3 2 1
Press any key to continue . . .

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



2、最大值优先级队列



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

priority_queue<int , vector<int>, less<int>> p;



代码示例 :

#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;
};

执行结果 :

首元素 : 5
容器大小 : 4
容器元素 : 5 3 2 1
Press any key to continue . . .

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



3、最小值优先级队列



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

priority_queue<int , vector<int>, greater<int>> p;



代码示例 :

#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;
};

执行结果 :

首元素 : 1
容器大小 : 4
容器元素 : 1 2 3 5
Press any key to continue . . .

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


标签:容器,优先级,队列,元素,queue,priority
From: https://blog.51cto.com/u_14202100/9066903

相关文章

  • 【C++】STL 容器 - list 双向链表容器 ① ( 容器特点 | 容器操作时间复杂度 | 构造函
    文章目录一、list双向链表容器简介1、容器特点2、容器操作时间复杂度3、遍历访问5、头文件二、list双向链表容器构造函数1、默认无参构造函数2、创建包含n个相同元素的list双向链表3、使用初始化列表构造list双向链表4、使用另外一个list容器构造list双向链表容器......
  • 【C++】STL 容器 - list 双向链表容器 ③ ( list 常用 api 简介 | 中间位置 插入 / 删
    文章目录一、list双向链表容器的中间位置插入元素1、在指定位置插入1个元素-insert函数2、在指定位置插入n个相同元素-insert函数3、中间位置插入另一个容器的指定范围内的元素-insert函数二、list双向链表容器的中间位置删除元素1、删除容器中所有元素......
  • 【C++】STL 容器 - queue 队列容器 ( queue 容器简介 | queue 容器特点 | push 函数 |
    文章目录一、queue队列容器简介1、queue队列容器引入2、queue队列容器特点二、queue队列常用api函数1、队尾插入函数-queue#push函数2、队头删除函数-queue#pop函数3、获取队首元素-queue#front函数一、queue队列容器简介1、queue队列容器引入queue队列容......
  • 【C++】STL 容器 - stack 堆栈容器 ① ( stack 堆栈容器特点 | stack 堆栈容器与 dequ
    文章目录一、stack堆栈容器简介1、stack堆栈容器引入2、stack堆栈容器特点3、stack堆栈容器与deque双端数组容器对比二、代码示例-stack堆栈容器简单示例1、代码示例2、执行结果一、stack堆栈容器简介1、stack堆栈容器引入C++语言中的STL标准模板库中的stac......
  • 从生活聊用消息队列的利弊 | 8月更文挑战
    为什么要选择消息队列?消息队列有什么优点?消息队列会带来哪些问题?消息队列的优点疫情当下,为了更好的防疫工作,食堂不再提供堂食,同学们需要把食物打包回公司吃,在公司吃跟堂食的区别是什么呢?然后小豆需要统计产品线需要带饭的有哪些人,负责把饭菜统一打包带回来。产品线主要划分三部分:设......
  • 使用容器快速在阿里云 ECS 多节点上搭建 Citus 12.1 集群
    阿里云ECS机器节点这里我们使用两台同一区域的ECS机器。机器配置:2核2G。(ps:阿里云99元一年的活动)一台安装coordinator(协调器),这里内网IP为172.18.60.11一台安装worker,这里内网IP为172.18.60.12操作系统两台机器分别安装了厂商的AlibabaCloudLinux3系统......
  • C++STL常用容器queue和stack
    2.5stack容器2.5.1stack基本概念概念:stack是一种先进后出(FirstInLastOut,FILO)的数据结构,它只有一个出口栈中只有顶端的元素才可以被外界使用,因此栈不允许有遍历行为栈中进入数据称为---入栈push栈中弹出数据称为---出栈pop生活中的栈:子弹进弹夹出弹夹的过程2.5.2s......
  • list容器
    #include<iostream>#include<list>//引入头文件#include<algorithm>usingnamespacestd;intmain(){ list<int>a; intb[]={1,2,3,4}; list<int>c(b,b+sizeof(b)/sizeof(int)); a.insert(a.begin(),c.begin(),c.end()); a.insert(a.beg......
  • list容器介绍代码
    #include<iostream>#include<list>#include<algorithm>usingnamespacestd;intmain(){ list<int>a; intb[]={1,2,3,4}; list<int>c(b,b+sizeof(b)/sizeof(int)); a.insert(a.begin(),3,1); //队头添加元素 a.push_front(0); //队尾添加元素......
  • list容器
    #include<iostream>#include<list>//引入list容器的头文件#include<algorithm>usingnamespacestd;intmain(){ list<int>a; intb[]={1,2,3,4}; list<int>c(b,b+sizeof(b)/sizeof(int)); a.insert(a.begin(),c.begin(),c.end()); a.in......