C++标注模板库(STL)-deque介绍

C++标准库中的deque是一个双端队列(double-ended queue),它支持在队列的前端和后端进行插入和删除操作。deque在内部使用了动态数组来实现,因此具有高效的随机访问性能。

deque基本操作

deque是C++标准库中的双端队列(double-ended queue),它支持在队列的前端和后端进行插入和删除操作。以下是一些基本的deque操作函数:

  1. push_front(): 在队列前端插入一个元素。
  2. push_back(): 在队列后端插入一个元素。
  3. pop_front(): 删除队列前端的一个元素。
  4. pop_back(): 删除队列后端的一个元素。
  5. front(): 返回队列前端元素。
  6. back(): 返回队列后端元素。
  7. empty(): 检查deque是否为空。
  8. size(): 返回deque中元素的数量。
  9. clear(): 删除deque中的所有元素。
  10. insert(iterator position, const value_type& val): 在迭代器position指定的位置之前插入值val
  11. erase(iterator position): 删除位于position的元素。
  12. erase(iterator first, iterator last): 删除位于范围[first, last)内的元素。
  13. swap(deque<T>& x): 与另一个deque交换内容。
  14. rbegin(): 返回指向deque后端的随机访问迭代器。
  15. rend(): 返回指向deque前端反向的随机访问迭代器。
  16. begin(): 返回指向deque前端的随机访问迭代器。
  17. end(): 返回指向deque后端反向的随机访问迭代器。

deque特性

  1. 具有动态大小:deque是一个动态数组,可以根据需要自动扩展或收缩容器。
  2. 两端可扩展:deque可以在前端或后端(或同时两端)进行插入和删除操作。
  3. 随机访问迭代器:deque允许通过随机访问迭代器直接访问各个元素。

请注意,不同的库可能以不同的方式实现deques,但在任何情况下,它们都允许通过随机访问迭代器直接访问各个元素,并通过根据需要扩展和收缩容器来自动处理存储。

应用举例

c++ 复制代码
#include <iostream>
#include <deque>

int main() {
    std::deque<int> d;

    // 在队列后端插入元素
    d.push_back(1);
    d.push_back(2);
    d.push_back(3);

    // 在队列前端插入元素
    d.push_front(0);
    d.push_front(4);

    // 删除队列前端元素
    d.pop_front();

    // 删除队列后端元素
    d.pop_back();

    // 遍历队列中的元素并输出
    for (int i : d) {
        std::cout << i << " ";
    }

    return 0;
}
相关推荐
liulilittle1 小时前
C++/CLI与标准C++的语法差异(一)
开发语言·c++·.net·cli·clr·托管·原生
daixin88481 小时前
什么是缓存雪崩?缓存击穿?缓存穿透?分别如何解决?什么是缓存预热?
java·开发语言·redis·缓存
小狄同学呀1 小时前
VS插件报错,g++却完美编译?API调用错因分析
c++
程序员编程指南1 小时前
Qt 数据库连接池实现与管理
c语言·数据库·c++·qt·oracle
你我约定有三1 小时前
RabbitMQ--消息丢失问题及解决
java·开发语言·分布式·后端·rabbitmq·ruby
小乖兽技术1 小时前
C#与C++交互开发系列(二十四):WinForms 应用中嵌入C++ 原生窗体
c++·c#·交互
张北北.2 小时前
【深入底层】C++开发简历4+4技能描述6
java·开发语言·c++
李永奉2 小时前
STM32-定时器的基本定时/计数功能实现配置教程(寄存器版)
c语言·开发语言·stm32·单片机·嵌入式硬件
go54631584652 小时前
中文语音识别与偏误检测系统开发
开发语言·人工智能·学习·生成对抗网络·数学建模·语音识别
NUC_Dodamce2 小时前
Cocos3x 解决同时勾选 适配屏幕宽度和 适配屏幕高度导致Widget组件失效的问题
开发语言·javascript·ecmascript