「C/C++」C++ STL容器库 之 std::deque 双端队列容器

| ✨博客主页 | ||
|---|---|---|
| 何曾参静谧的博客 | ||
| 📌文章专栏 | ||
| 「C/C++」C/C++程序设计 | ||
| 📚全部专栏 | ||
| 「VS」Visual Studio | 「C/C++」C/C++程序设计 | 「UG/NX」BlockUI集合 |
| 「Win」Windows程序设计 | 「DSA」数据结构与算法 | 「UG/NX」NX二次开发 |
| 「QT」QT5程序设计 | 「File」数据文件格式 | 「PK」Parasolid函数说明 |
目录
- std::deque 容器详解
- 1. 引用头文件
- 2. 函数构造与对象初始化
- 3. 对象初始化与元素访问
- 4. 迭代器
- 5. 容器操作
- 6. 修改器
- 7. 元素比较
- 总结
- 应用场景
std::deque 容器详解
std::deque(双端队列)是C++标准模板库(STL)中的一种序列容器,它提供了动态数组的功能,但与std::vector不同的是,std::deque允许在容器的两端高效地插入和删除元素。本文将详细介绍std::deque的使用,包括引用头文件、函数构造、对象初始化、元素访问、迭代器、容器操作、修改器以及元素比较等方面。

上图截图为黑马C++课程
1. 引用头文件
要使用std::deque,首先需要包含相应的头文件:
#include <deque>
2. 函数构造与对象初始化
std::deque提供了多种构造函数来创建和初始化容器对象。
#include <iostream>
#include <deque>int main() {// 1. 默认构造函数,创建一个空的双端队列std::deque<int> dq1;// 2. 填充构造函数,创建一个包含5个元素的双端队列,所有元素初始化为0std::deque<int> dq2(5, 0);// 3. 列表初始化构造函数,创建一个包含指定元素的双端队列std::deque<int> dq3 = {1, 2, 3, 4, 5};// 输出dq3的内容for (int n : dq3) {std::cout << n << " ";}std::cout << std::endl;return 0;
}
3. 对象初始化与元素访问

在创建std::deque对象后,可以通过多种方式访问其元素。
#include <iostream>
#include <deque>int main() {std::deque<int> dq = {10, 20, 30, 40, 50};// 1. 使用下标操作符访问元素std::cout << "Element at index 2: " << dq[2] << std::endl; // 输出30// 2. 使用at函数访问元素(带边界检查)try {std::cout << "Element at index 4: " << dq.at(4) << std::endl; // 输出50} catch (const std::out_of_range& e) {std::cerr << "Out of range error: " << e.what() << std::endl;}// 3. 使用front和back函数访问第一个和最后一个元素std::cout << "First element: " << dq.front() << std::endl; // 输出10std::cout << "Last element: " << dq.back() << std::endl; // 输出50return 0;
}
4. 迭代器

std::deque支持双向迭代器,允许在容器中向前和向后遍历元素。
#include <iostream>
#include <deque>int main() {std::deque<int> dq = {1, 2, 3, 4, 5};// 1. 使用正向迭代器遍历双端队列for (std::deque<int>::iterator it = dq.begin(); it != dq.end(); ++it) {std::cout << *it << " ";}std::cout << std::endl;// 2. 使用反向迭代器遍历双端队列for (std::deque<int>::reverse_iterator rit = dq.rbegin(); rit != dq.rend(); ++rit) {std::cout << *rit << " ";}std::cout << std::endl;return 0;
}
5. 容器操作

std::deque提供了多种容器操作函数,如size、empty、resize、max_size和swap。
#include <iostream>
#include <deque>int main() {std::deque<int> dq = {1, 2, 3};// 1. 获取容器大小std::cout << "Size of deque: " << dq.size() << std::endl; // 输出3// 2. 检查容器是否为空std::cout << "Is deque empty? " << (dq.empty() ? "Yes" : "No") << std::endl; // 输出No// 3. 调整容器大小(如果新大小大于当前大小,则新元素初始化为0)dq.resize(5);std::cout << "Size after resize: " << dq.size() << std::endl; // 输出5// 4. 获取容器能容纳的最大元素数量std::cout << "Max size of deque: " << dq.max_size() << std::endl;// 5. 交换两个容器的内容std::deque<int> dq2 = {10, 20, 30};dq.swap(dq2);std::cout << "dq after swap: ";for (int n : dq) {std::cout << n << " ";}std::cout << std::endl; // 输出10 20 30return 0;
}
6. 修改器

std::deque提供了多种修改器函数来插入、删除和替换元素。
#include <iostream>
#include <deque>int main() {std::deque<int> dq = {1, 2, 3, 4, 5};// 1. 在末尾插入元素dq.push_back(6);// 2. 在开头插入元素dq.push_front(0);// 输出dq的内容std::cout << "Deque after push_back and push_front: ";for (int n : dq) {std::cout << n << " ";}std::cout << std::endl; // 输出0 1 2 3 4 5 6// 3. 从末尾删除元素dq.pop_back();// 4. 从开头删除元素dq.pop_front();// 输出dq的内容std::cout << "Deque after pop_back and pop_front: ";for (int n : dq) {std::cout << n << " ";}std::cout << std::endl; // 输出1 2 3 4 5// 5. 在指定位置插入元素dq.insert(dq.begin() + 2, 99);// 输出dq的内容std::cout << "Deque after insert: ";for (int n : dq) {std::cout << n << " ";}std::cout << std::endl; // 输出1 2 99 3 4 5// 6. 删除指定位置的元素dq.erase(dq.begin() + 2);// 输出dq的内容std::cout << "Deque after erase: ";for (int n : dq) {std::cout << n << " ";}std::cout << std::endl; // 输出1 2 3 4 5return 0;
}
7. 元素比较

虽然std::deque本身不直接提供元素比较的成员函数,但可以使用标准库中的算法函数(如std::equal)来比较两个std::deque对象的内容。
#include <iostream>
#include <deque>
#include <algorithm> // for std::equalint main() {std::deque<int> dq1 = {1, 2, 3, 4, 5};std::deque<int> dq2 = {1, 2, 3, 4, 5};std::deque<int> dq3 = {1, 2, 3, 6, 5};// 比较两个双端队列是否相等(按元素顺序和值)bool areEqual1 = std::equal(dq1.begin(), dq1.end(), dq2.begin());bool areEqual2 = std::equal(dq1.begin(), dq1.end(), dq3.begin());std::cout << "dq1 and dq2 are equal? " << (areEqual1 ? "Yes" : "No") << std::endl; // 输出Yesstd::cout << "dq1 and dq3 are equal? " << (areEqual2 ? "Yes" : "No") << std::endl; // 输出Noreturn 0;
}
总结
std::deque(双端队列)是C++标准模板库(STL)中一个非常灵活且功能强大的序列容器。它结合了std::vector的动态数组特性和std::list的双向链表特性,允许在容器的两端高效地插入和删除元素,同时提供了随机访问功能。
应用场景
-
动态数组扩展:
- 当需要一个可以动态调整大小的数组,并且需要在数组的两端频繁插入或删除元素时,
std::deque是一个很好的选择。与std::vector相比,std::deque在两端插入和删除元素时的性能更优,因为它不需要像std::vector那样在内存中进行大量的数据搬移。
- 当需要一个可以动态调整大小的数组,并且需要在数组的两端频繁插入或删除元素时,
-
队列和栈的实现:
std::deque可以很方便地用作队列(FIFO,先进先出)和栈(LIFO,后进先出)的实现。对于队列,可以使用push_back在尾部插入元素,使用pop_front在头部删除元素;对于栈,则可以使用push_front在头部插入元素,使用pop_front在头部删除元素。
-
滑动窗口算法:
- 在处理滑动窗口问题时,
std::deque可以高效地存储当前窗口内的元素,并允许在窗口的两端进行快速的插入和删除操作。这对于解决一些数组或字符串处理中的滑动窗口问题特别有用。
- 在处理滑动窗口问题时,
-
缓存和缓冲区:
std::deque可以用作缓存或缓冲区,存储临时数据。由于它允许在两端进行高效的插入和删除操作,因此非常适合用于需要频繁更新数据结构的场景。
-
数据流的处理:
- 在处理数据流时,
std::deque可以存储最近接收到的数据,并根据需要丢弃旧数据或添加新数据。这对于实时数据处理和流处理应用特别有用。
- 在处理数据流时,
-
算法和数据结构中的辅助容器:
- 在实现一些复杂的算法和数据结构时,
std::deque可以作为辅助容器来存储中间结果或临时数据。它的高效性和灵活性使其成为许多算法和数据结构实现中的理想选择。
- 在实现一些复杂的算法和数据结构时,
综上所述,std::deque是一个功能强大且灵活的容器,适用于多种应用场景。它的高效性和易用性使其成为C++程序员在处理动态数据结构时的有力工具。

相关文章:
「C/C++」C++ STL容器库 之 std::deque 双端队列容器
✨博客主页何曾参静谧的博客📌文章专栏「C/C」C/C程序设计📚全部专栏「VS」Visual Studio「C/C」C/C程序设计「UG/NX」BlockUI集合「Win」Windows程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计「File」数据文件格式「PK」Parasoli…...
一招教你解决Facebook广告账号问题
这段时间,我们写了很多文章来探讨Facebook的广告账户问题:《Facebook被封号该怎么办》《Facebook二不限、三不限账号是什么》《Facebook海外户(三不限)和账单户该如何选择》《如何区分真假Facebook三不限海外户》相信看过这些文章…...
MySQL启动报错:InnoDB: Unable to lock ./ibdata1 error
MySQL启动报错:InnoDB: Unable to lock ./ibdata1 error 在OS X环境下MySQL启动时报错: 016-03-03T00:02:30.483037Z 0 [ERROR] InnoDB: Unable to lock ./ibdata1 error: 35 2016-03-03T00:02:30.483100Z 0 [Note] InnoDB: Check that you do not alr…...
Linux终端之旅: 打包和压缩
在 Linux 世界中,打包和压缩文件是管理系统资源、传输数据和备份的重要技能。通过命令行工具如 tar、gzip、zip 等,我们可以高效地将多个文件或目录打包为一个文件,并通过压缩减少其体积。接下来,我将记录学习如何利用这些工具&am…...
PDA手持机提升管理效率和准确性
在当今快节奏的商业世界中,管理效率和准确性是企业成功的关键因素。而 PDA 手持机的出现,为企业管理带来了革命性的变革,成为提升管理效率和准确性的有力武器。 PDA 手持机,即个人数字助理手持设备,集数据采集、存储、…...
C++ [项目] 愤怒的小鸟
现在才发现C游戏的支持率这么高,那就发几篇吧 零、前情提要 此篇为 制作,由于他没有CSDN,于是由我代发 一、基本介绍 支持Dev-C5.11版本(务必调为英文输入法),基本操作看游戏里的介绍,怎么做的……懒得说,能看懂就看注释,没有的自己猜,如果你很固执……私我吧 …...
群控系统服务端开发模式-市场分析
刚刚我把群控系统服务端开发模式的文档全部整理了一下,结果发现还缺市场分析这篇文档没有上传,不好意思啦。 一、前言 在互联网高速发展且稳定的时代,营销系统是自运营公司线上最好的系统。加上现在直播行业很火,引流很重要&#…...
智能听诊器革新宠物健康监测
在宠物健康护理领域,智能听诊器的引入标志着一个新时代的开启,它正成为宠物医疗保健的新宠。这款设备通过高精度传感器捕捉宠物的心跳和呼吸声,为宠物主人和兽医提供精确的健康数据。 智能听诊器的即时反馈功能,使得主人能够通过…...
2000-2023年上市公司绿色专利申请授权面板数据
2000-2023年上市公司绿色专利申请授权面板数据 1、时间:2000-2023年 2、来源:国家知识产权局、WPIO清单 3、指标:年份、股票代码、股票简称、行业名称、行业代码、省份、城市、区县、区县代码、上市状态、绿色专利申请总量、绿色发明专利申…...
vue使用xlsx以及file-saver进行下载xlsx文件以及Unit8Array、ArrayBuffer、charCodeAt的使用
先说Unit8Array、ArrayBuffer、charCodeAt的使用下面会用到这三个 Unit8Array:数组类型表示一个 8 位无符号整型数组,创建时内容被初始化为 0。创建完后,可以以对象的方式或使用数组下标索引的方式引用数组中的元素。 new Uint8Array(); //…...
日语表目的的两个句型,柯桥成人零基础日语培训
句型: (能做动词的)名词(或动词连用形)に来ました(或行きます) 例句: わたしは日本へ文学の勉強に来ました。/我是到日本来学习文学的。 翻译: (我&#…...
小程序中设置可拖动区域
官方说明文档:https://developers.weixin.qq.com/miniprogram/dev/component/movable-area.htmlhttps://developers.weixin.qq.com/miniprogram/dev/component/movable-view.html demo:浮动控件上下移动交互 .wxmx <movable-area><!-- y"…...
前端后台管理开发
1通常项目从头开发,有人是二开,有人是从头,也有人是复制之前人留的。 2通常要自己写就很费时间,多数都是接别人的二手代码继续干,导致很多人没有从头开发的经验,做两三年。 3项目开始一般要选择搭建环境&am…...
GDAL+C#实现矢量多边形转栅格
1. 开发环境测试 参考C#配置GDAL环境,确保GDAL能使用,步骤简述如下: 创建.NET Framework 4.7.2的控制台应用 注意: 项目路径中不要有中文,否则可能报错:can not find proj.db 在NuGet中安装GDAL 3.9.1和G…...
Python 爬虫实战之爬拼多多商品做数据分析
一、项目背景 在电商领域,拼多多作为一家具有广泛影响力的平台,拥有大量的商品信息和用户数据。通过爬取拼多多商品数据并进行分析,可以了解市场趋势、消费者需求以及竞争对手情况,为企业决策和产品优化提供有力支持。 二、技术准…...
爬虫基础
maven pom <dependencies><!--前端jqury--><dependency><groupId>org.jsoup</groupId><artifactId>jsoup</artifactId><version>1.16.1</version></dependency><!--http工具--><dependency><grou…...
HTML3D旋转相册
文章目录 序号目录1HTML满屏跳动的爱心(可写字)2HTML五彩缤纷的爱心3HTML满屏漂浮爱心4HTML情人节快乐...
[linux]快速入门
学习目标 通过学习能够掌握以下的linux操作 操作系统 按照应用领域的不同, 操作系统可以分为几类 桌面操作系统服务器操作系统移动设备操作系统嵌入式操作系统 不同领域的主流操作系统 桌面操作系统 Windows(用户数量最多)MacOS(操作体验好,办公人士首选)Linux…...
域3:安全工程 第6章 密码学与对称密钥算法
---域3主要包括OSG 6、7、8、9、10 章--- 随着信息化时代的推进,网络安全愈发关键。CISSP认证考试中的第6章,专注于密码学与对称密钥算法,这两者是网络安全的核心。 密码学,历经演变,从古代简单的替代密码到现代的复杂…...
MySQL注入load_file常用路径
在MySQL注入攻击中,攻击者可能会尝试利用LOAD_FILE()函数来读取服务器上的敏感文件。LOAD_FILE()函数允许从服务器的文件系统中读取文件,并将其内容作为字符串返回。然而,这个函数需要满足一定的权限条件,并且文件路径必须是服务器…...
观成科技:隐蔽隧道工具Ligolo-ng加密流量分析
1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具,该工具基于TUN接口实现其功能,利用反向TCP/TLS连接建立一条隐蔽的通信信道,支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式,适应复杂网…...
【根据当天日期输出明天的日期(需对闰年做判定)。】2022-5-15
缘由根据当天日期输出明天的日期(需对闰年做判定)。日期类型结构体如下: struct data{ int year; int month; int day;};-编程语言-CSDN问答 struct mdata{ int year; int month; int day; }mdata; int 天数(int year, int month) {switch (month){case 1: case 3:…...
Lombok 的 @Data 注解失效,未生成 getter/setter 方法引发的HTTP 406 错误
HTTP 状态码 406 (Not Acceptable) 和 500 (Internal Server Error) 是两类完全不同的错误,它们的含义、原因和解决方法都有显著区别。以下是详细对比: 1. HTTP 406 (Not Acceptable) 含义: 客户端请求的内容类型与服务器支持的内容类型不匹…...
HTML 列表、表格、表单
1 列表标签 作用:布局内容排列整齐的区域 列表分类:无序列表、有序列表、定义列表。 例如: 1.1 无序列表 标签:ul 嵌套 li,ul是无序列表,li是列表条目。 注意事项: ul 标签里面只能包裹 li…...
质量体系的重要
质量体系是为确保产品、服务或过程质量满足规定要求,由相互关联的要素构成的有机整体。其核心内容可归纳为以下五个方面: 🏛️ 一、组织架构与职责 质量体系明确组织内各部门、岗位的职责与权限,形成层级清晰的管理网络…...
在四层代理中还原真实客户端ngx_stream_realip_module
一、模块原理与价值 PROXY Protocol 回溯 第三方负载均衡(如 HAProxy、AWS NLB、阿里 SLB)发起上游连接时,将真实客户端 IP/Port 写入 PROXY Protocol v1/v2 头。Stream 层接收到头部后,ngx_stream_realip_module 从中提取原始信息…...
基于数字孪生的水厂可视化平台建设:架构与实践
分享大纲: 1、数字孪生水厂可视化平台建设背景 2、数字孪生水厂可视化平台建设架构 3、数字孪生水厂可视化平台建设成效 近几年,数字孪生水厂的建设开展的如火如荼。作为提升水厂管理效率、优化资源的调度手段,基于数字孪生的水厂可视化平台的…...
《通信之道——从微积分到 5G》读书总结
第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...
Nuxt.js 中的路由配置详解
Nuxt.js 通过其内置的路由系统简化了应用的路由配置,使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...
鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院查看报告小程序
一、开发环境准备 工具安装: 下载安装DevEco Studio 4.0(支持HarmonyOS 5)配置HarmonyOS SDK 5.0确保Node.js版本≥14 项目初始化: ohpm init harmony/hospital-report-app 二、核心功能模块实现 1. 报告列表…...
