0

0

C++如何使用std::deque双端队列?(容器用法)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-12-13 10:35:50

|

378人浏览过

|

来源于php中文网

原创

std::deque是支持首尾O(1)增删和O(1)随机访问的分段连续序列容器,适合需频繁首尾操作又需索引访问的场景,但内存不连续、缓存局部性弱于vector。

c++如何使用std::deque双端队列?(容器用法)

std::deque(double-ended queue)是C++标准库中支持两端高效插入和删除的序列容器,底层通常以分段连续空间实现,兼顾了vector的随机访问和list的部分动态性。它不保证内存整体连续,但支持O(1)的头尾操作和O(1)的随机访问(下标/迭代器),适合频繁在首尾增删、又需要按索引读写的场景。

基本声明与初始化

包含头文件 #include 后即可使用:

  • 空构造std::deque dq;
  • 指定大小并初始化为默认值std::deque dq(5); // 元素全为0
  • 指定大小并初始化为给定值std::deque dq(5, 42); // 5个42
  • 用初始化列表构造(C++11起)std::deque<:string> dq{"a", "b", "c"};
  • 拷贝或移动构造std::deque dq2 = dq1;std::deque dq2 = std::move(dq1);

常用增删查改操作

所有操作均在头尾保持常数时间复杂度(摊还),中间插入/删除仍是O(n),应避免。

  • 尾部操作dq.push_back(x)dq.pop_back()dq.back()(访问末元素,不检查空)
  • 头部操作dq.push_front(x)dq.pop_front()dq.front()(访问首元素,不检查空)
  • 随机访问dq[i]dq.at(i)(后者带越界检查,抛出std::out_of_range
  • 插入任意位置dq.insert(dq.begin() + pos, value) 或批量插入 dq.insert(it, first, last)
  • 删除任意位置dq.erase(it) 或区间 dq.erase(first, last)

遍历与容量管理

支持基于范围的for循环、迭代器遍历,也提供常见容量接口:

GemDesign
GemDesign

AI高保真原型设计工具

下载

立即学习C++免费学习笔记(深入)”;

  • 迭代器遍历for (auto it = dq.begin(); it != dq.end(); ++it) { ... } 或更简洁的 for (const auto& x : dq) { ... }
  • 获取大小与状态dq.size()dq.empty()dq.max_size()
  • 调整容量dq.resize(n)(增补默认值或截断)、dq.clear()(清空,但不释放内存)
  • 释放冗余内存(C++11后)std::deque(dq).swap(dq); —— 利用临时对象交换来收缩内存(注意:deque的shrink_to_fit不是标准要求,多数实现不支持)

注意事项与适用建议

deque不是万能替代vector或list,需结合使用场景判断:

  • 不要假设内存连续——&dq[0]&dq[dq.size()-1] 不一定可作C数组用
  • 迭代器可能失效:头尾插入/删除不会使其他迭代器失效(这点优于vector),但中间修改会
  • 元素类型需满足可复制/可移动;若含指针成员,注意深浅拷贝语义
  • 当主要操作是尾部增删+随机访问 → 优先用vector;当频繁头插头删且不要求随机访问 → list更合适;当两者都要 → deque是合理选择
  • 小对象(如int、char)性能差异不大;大对象时,deque的分段结构可能导致缓存局部性略差于vector

基本上就这些。用好deque的关键是明确“我是否真需要在开头高效操作”,而不是因为名字带“队列”就默认选用它。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

401

2023.08.02

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

527

2023.09.20

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

401

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

543

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

101

2025.10.23

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

58

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 7.6万人学习

C 教程
C 教程

共75课时 | 4.2万人学习

C++教程
C++教程

共115课时 | 13.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号