C++队列queue用法详解

一、queue的介绍

1. 队列是一种容器适配器,专门用于在 FIFO 上下文 ( 先进先出 ) 中操作,其中从容器一端插入元素,另一端 提取元素。
2. 队列作为容器适配器实现,容器适配器即将特定容器类封装作为其底层容器类, queue 提供一组特定的 成员函数来访问其元素。元素从队尾入队列,从队头出队列。
3.就好比我们排队一样,先来的先进行处理。
4.queue的底层是一个容器,是deque的容器,可以自己了解

二、queue的简单使用和初始化

      1.queue的使用需要包头文件:

#include<queue>

定义时:

<>尖括号里是队列存放数据的类型

queue<int> q1;//int型

queue<double> q2//double型

2.queue的操作

  1. back() 返回队列中最后一个元素
  2. push() 在队尾插入一个元素
  3. size() 返回队列中元素个数
  4. empty() 如果队列空则返回true
  5. front() 返回队列中的第一个元素
  6. pop() 删除队列第一个元素

三、对于队列的深入理解

他的底层使用的是deque的容器,当然也可以使用list的容器来实现。简单点,就是调用其他容器来实现他的结构和功能

deque( 双端队列 ) :是一种双开口的 " 连续 " 空间的数据结构 ,双开口的含义是:可以在头尾两端进行插入和 删除操作,且时间复杂度为O(1) ,与 vector 比较,头插效率高,不需要搬移元素;与 list 比较,空间利用率比 较高。
只要一个容器中支持以下的函数,就可以当作queue的底层容器:
  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要清除C++中的queue,有几种方法可以实现。 方法一是使用pop()函数逐个删除队列中的元素,直到队列为空。这样可以确保队列被完全清空。 方法二是使用clear()函数,该函数会清空队列中的所有元素。可以通过调用queue的成员函数clear()来实现。 方法三是使用swap()函数,这是最高效的方法。可以定义一个空的queue,然后通过调用swap()函数将空的queue与原始queue进行交换,从而实现清空队列的目的。 以下是使用swap()函数清空queue的示例代码: ```cpp void clear(queue<int>& q) { queue<int> empty; swap(empty, q); } ``` 这样,调用clear()函数后,原始的queue将被清空。 请注意,以上方法适用于C++标准库中的queue容器。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [C++:queue 详解](https://blog.csdn.net/qq_44861043/article/details/120034441)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [C++ 清空队列(queue)的几种方法](https://blog.csdn.net/tjcwt2011/article/details/114684927)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Though even

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值