C++优先队列的使用小结

 更新时间:2023年11月22日 08:26:13   作者:飞翔的云中猪  
普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除,在优先队列中,元素被赋予优先级,本文主要介绍了C++优先队列的使用,感兴趣的可以了解一下

1. 什么是priority_queue

priority_queue是C++中的容器,实现优先队列。由于底层采用堆实现,所以插入和删除操作的时间复杂度为O(logn),查找队首元素的时间复杂度为O(1)。

2. 构造priority_queue

【1】使用priority_queue需要先包含头文件<queue>。以下是priority_queue的基本语法:

#include <queue>
priority_queue<int> pq;

默认情况下,priority_queue是一个大顶堆,即队首元素是最大的元素,由大到小排序

【2】如果是自定义比较,比如比较从小到大比较或不坏类中的某个元素,则在声明priority_queue对象时,需要指定元素类型和比较函数。

具体语法:

// 声明一个元素类型为T,比较函数为Compare的priority_queue对象
priority_queue<T, vector<T>, Compare> pq;

其中,T为元素类型,std::vector<T>为底层容器类型,Compare为元素的比较函数,是函数对象。

例如若要声明一个整型优先队列,要求从小到大排序,可以这样写:

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

例如若要声明一个字符串优先队列,要求按照字符串大小从小到大排序,可以这样写:

// 自定义比较函数
struct cmp {
    bool operator() (const std::string& s1, const std::string& s2) {
        return s1.size() > s2.size();  // 按字符串长度从小到大排序
    }
};

priority_queue<string, vector<string>, cmp> pq;

【3】用已有的优先队列赋值

priority_queue<int> pq(vec.begin(), vec.end()); // 创建一个包含vec中所有元素的优先队列

3. priority_queue的常用操作

3.1 插入元素

使用成员函数push()可以向priority_queue中插入一个元素,插入后会自动按照优先级调整元素位置。

pq.push(10); // 向队列中插入元素10 pq.push(20); // 向队列中插入元素20

3.2 访问队首元素

使用成员函数top()可以访问priority_queue中的队首元素,即最大(小)值。

int max_element = pq.top(); // 获取大顶堆的队首元素,即最大值

3.3 删除队首元素

使用成员函数pop()可以删除priority_queue中的队首元素,即最大(小)值。

pq.pop(); // 删除大顶堆的队首元素,即最大值

3.4 检查队列是否为空

使用成员函数empty()可以检查priority_queue是否为空。

if (pq.empty()) { 
    // 队列为空 
}

3.5 获取队列大小

使用成员函数size()可以获取priority_queue中元素的个数。

int count = pq.size(); // 获取队列中元素的个数

到此这篇关于C++优先队列的使用小结的文章就介绍到这了,更多相关C++优先队列内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • C++实现LeetCode(107.二叉树层序遍历之二)

    C++实现LeetCode(107.二叉树层序遍历之二)

    这篇文章主要介绍了C++实现LeetCode(107.二叉树层序遍历之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C++利用libcurl获取下载文件名称及大小

    C++利用libcurl获取下载文件名称及大小

    这篇文章主要为大家详细介绍了C++如何利用libcurl获取下载文件名称及大小的功能,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2023-03-03
  • C++中auto_ptr智能指针的用法详解

    C++中auto_ptr智能指针的用法详解

    这篇文章主要介绍了C++中auto_ptr智能指针的用法详解的相关资料,需要的朋友可以参考下
    2016-07-07
  • C++编译原理之求解First集合

    C++编译原理之求解First集合

    这篇文章主要介绍的是C++/编译原理求解First集合,本文将围绕该话题详细展开全文,需要的小伙伴可以参考一下
    2021-10-10
  • C语言中怎么在main函数开始前执行函数

    C语言中怎么在main函数开始前执行函数

    C语言中怎么在main函数开始前执行函数呢?下面小编就大家详细的介绍一下。需要的朋友可以过来参考下,希望对大家有所帮助
    2013-10-10
  • 使用C语言来解决循环队列问题的方法

    使用C语言来解决循环队列问题的方法

    这篇文章主要介绍了使用C语言来解决循环队列问题的方法,来自ACM的练习题实例,需要的朋友可以参考下
    2015-08-08
  • C++实现邻接表顶点的删除

    C++实现邻接表顶点的删除

    这篇文章主要为大家详细介绍了C++实现邻接表顶点的删除,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • C++实现简易的弹球小游戏

    C++实现简易的弹球小游戏

    这篇文章主要为大家详细介绍了C++实现简易的弹球小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • Opencv实现读取摄像头和视频数据

    Opencv实现读取摄像头和视频数据

    这篇文章主要为大家详细介绍了Opencv实现读取摄像头和视频数据,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • C语言实现贪吃蛇游戏代码

    C语言实现贪吃蛇游戏代码

    这篇文章主要为大家详细介绍了C语言实现贪吃蛇游戏代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09

最新评论