deque、queue 和 priority_queue 的区别

在 C++ 标准库中,std::dequestd::queuestd::priority_queue 是三种不同的容器和容器适配器,它们各自有不同的特性和用途:

std::deque(双端队列)

  • 特性std::deque(double-ended queue)是一个双端队列,它支持在序列的前端和后端快速插入和删除元素。
  • 随机访问 :提供对序列中任意位置的快速访问,支持 operator[]at() 方法。
  • 内存分配:通常由多个固定大小的数组块组成,这些块在内存中可能不连续。
  • 使用场景:适合需要在序列两端进行操作的场合,如实现双端队列、某些类型的缓存等。

std::deque 的常用函数:

  • push_back(value):在序列的后端插入一个新元素。
  • push_front(value):在序列的前端插入一个新元素。
  • pop_back():移除序列后端的元素。
  • pop_front():移除序列前端的元素。
  • operator[](index):访问序列中指定位置的元素。
  • at(index):访问序列中指定位置的元素,带边界检查。
  • size():返回序列中元素的数量。
  • clear():移除序列中的所有元素。

std::queue

  • 特性std::queue 是一个容器适配器,提供了先进先出(FIFO)的数据结构。
  • 受限访问:只允许在队尾插入元素,在队首移除元素,不支持随机访问。
  • 底层容器 :通常使用 std::dequestd::list 作为底层容器,但用户无法直接访问这些容器。
  • 使用场景:适合需要先进先出行为的场合,如任务调度、广度优先搜索等。

std::queue 的常用函数:

  • push(value):在队列的后端插入一个新元素。
  • pop():移除队列前端的元素。
  • front():访问队列前端的元素。
  • back():访问队列后端的元素。
  • empty():检查队列是否为空。
  • size():返回队列中元素的数量。
  • swap(other):交换两个队列的内容。

std::priority_queue

  • 特性std::priority_queue 是一个容器适配器,它提供了一个优先级队列,元素根据优先级出队,而不是按照它们被添加的顺序。
  • 受限访问:只允许访问队首元素,即优先级最高的元素。
  • 底层容器 :通常使用 std::vector 作为底层容器,并以最大堆的形式组织元素,但用户无法直接访问这些容器。
  • 使用场景:适合需要根据优先级处理元素的场合,如任务调度、事件驱动模拟、Dijkstra 算法等。

std::priority_queue 的常用函数:

  • push(value):在优先级队列中插入一个新元素。
  • pop():移除优先级最高的元素(通常位于队首)。
  • top():访问优先级最高的元素。
  • empty():检查优先级队列是否为空。
  • size():返回优先级队列中元素的数量。
  • swap(other):交换两个优先级队列的内容。

区别总结

  • 访问方式std::deque 支持两端和中间的随机访问,std::queuestd::priority_queue 只允许访问队首元素。
  • 元素顺序std::queue 按照先进先出的顺序处理元素,std::priority_queue 根据元素的优先级处理元素,而 std::deque 不维护元素的特定顺序。
  • 底层实现std::deque 通常由多个数组块组成,std::queuestd::priority_queue 通常使用 std::dequestd::vectorstd::list 作为底层容器,但这些底层容器对用户是隐藏的。
  • 适用场景:根据需要的数据结构特性选择合适的容器或容器适配器。
相关推荐
small_wh1te_coder3 天前
GCC深度剖析:从编译原理到嵌入式底层实战
汇编·c++·面试·嵌入式·状态模式·c
一个高效工作的家伙5 天前
amis表单较验
状态模式
zhysunny9 天前
20.万物皆可变身术:状态模式架构全景解析
java·状态模式
橘色的喵11 天前
嵌入式C语言编程:策略模式、状态模式和状态机的应用
c语言·状态模式·策略模式·状态机
跟着珅聪学java12 天前
Spring MVC 教程
状态模式
小傅哥13 天前
【分享】拼团交易平台系统,分布式、高并发、微服务
分布式·微服务·状态模式
mit6.82415 天前
[Agent开发平台] API网关 | 业务领域 | DTO格式 | 分页令牌
人工智能·golang·状态模式
飏旎17 天前
对于前端闭包的详细理解
前端·状态模式
曾经的三心草17 天前
微服务的编程测评系统9-竞赛新增-竞赛编辑
微服务·架构·状态模式
Haven-18 天前
黑马商城微服务-下
微服务·架构·状态模式