C语言到C++STL菜鸟教程:Priority_queue(优先队列)

2023年 7月 12日 34.3k 0

1. 简介

优先队列是一种极其特殊的队列,他与标准的队列使用线性结构进行计算不同,优先队列的底层是以散列的状态(非线性)表现的,他与标准的队列有如下的区别,标准的队列遵从严格的先进先出,优先队列并不遵从标准的先进先出,而是对每一个数据赋予一个权值,根据当前队列权值的状态进行排序,使得权值最大(或最小)的永远排在队列的最前面。

2. 相关文件

由于其属于队列的一种,因此可以直接使用队列的头文件#include

3. 初始化

priority_queuepriority_queue        //直接输入元素则使用默认容器和比较函数

与往常的初始化不同,优先队列的初始化涉及到一组而外的变量,这里解释一下初始化:

a) T就是Type为数据类型

b) Container是容器类型,(Container必须是用数组实现的容器,比如vector,deque等等,但不能用 list。STL里面默认用的是vector)

c) Compare是比较方法,类似于sort第三个参数那样的比较方式,对于自定义类型,需要我们手动进行比较运算符的重载。与sort直接Bool一个函数来进行比较的简单方法不同,Compare需要使用结构体的运算符重载完成,直接bool cmp(int a,int b){  return a>b; } 这么写是无法通过编译的。

使用的举例有:

struct cmp//这个比较要用结构体表示    bool operator()(int &a, int &b) const    {        return a > b;    }}; priority_queue q;    //使用自定义比较方法priority_queue pq;

4. 常用接口

我们预先通过priority_queue q创建了一个队列,命名为q,方便举例。

a)大小size()

返回队列元素的个数

函数原型:size_type size() const;

cout

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论