0

0

c++中deque怎么使用_c++双端队列操作方法【入门】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-02-09 11:04:02

|

254人浏览过

|

来源于php中文网

原创

deque不是vector替代品,适合首尾频繁增删、少随机访问中间元素的场景;声明初始化有空构造、指定大小初值、迭代器范围构造和初始化列表四种方式。

c++中deque怎么使用_c++双端队列操作方法【入门】

deque 不是 vector 的替代品,它适合频繁在首尾增删、但不常随机访问中间元素的场景;误用会导致性能意外下降。

如何声明和初始化 deque

deque 是 C++ 标准库中的双端队列容器,头文件为 。它支持在头部和尾部高效插入/删除(均摊 O(1)),但随机访问虽为 O(1),实际缓存局部性不如 vector

常见初始化方式:

  • std::deque dq; —— 空 deque
  • std::deque dq(5, 42); —— 含 5 个值为 42 的元素
  • std::deque dq(v.begin(), v.end()); —— 从其他容器(如 vector)迭代器范围构造
  • std::deque dq = {1, 2, 3}; —— C++11 起支持初始化列表(注意:不是所有编译器对大列表做优化,小数据量安全)

首尾插入与删除操作必须用对函数

deque 提供四组明确语义的操作函数,混用 push_backpop_front 很常见,但写错名字(比如写成 push_front() 拼错)会直接编译失败;更隐蔽的问题是误把 front() 当作删除——它只返回引用,不移除元素。

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

OmniAudio
OmniAudio

OmniAudio 是一款通过 AI 支持将网页、Word 文档、Gmail 内容、文本片段、视频音频文件都转换为音频播客,并生成可在常见 Podcast ap

下载
  • 尾部操作:push_back()pop_back()back()
  • 头部操作:push_front()pop_front()front()
  • pop_front()pop_back() 无返回值,调用前必须确保非空,否则行为未定义(不会抛异常)
  • 若需“取并删”,得手动组合:例如 auto x = dq.front(); dq.pop_front();

迭代器失效规则比 vector 更宽松,但仍有陷阱

deque 的迭代器在首尾插入/删除时通常不失效(这是它相比 vector 的关键优势),但以下情况仍会失效:

  • 调用 erase() 删除中间元素时,被删位置及之后的迭代器全部失效
  • 调用 clear() 或移动赋值(dq = std::move(other))后,所有迭代器失效
  • 虽然 insert() 在首尾插入不使迭代器失效,但在中间插入(如 dq.insert(dq.begin() + 3, 99))可能导致部分迭代器失效(标准未保证,各实现不同,应避免依赖)

实践中,只要坚持“只在两端增删”,基本可放心使用迭代器遍历。

什么时候不该用 deque

deque 内部通常以分段连续内存块实现(如 chunk 数组),这带来额外指针跳转开销。以下情况建议换用其他容器:

  • 需要大量随机访问(如频繁 dq[i]i 分布广泛)→ 改用 vector
  • 内存极度受限或要求严格连续布局(如对接 C API)→ vector 或裸数组
  • 仅需单端操作(如只在尾部 push/pop)→ vector 更轻量,且现代编译器对其 push_back() 优化极好
  • 要存储大型对象且频繁移动 → 注意 deque 的移动构造/赋值虽为 O(1),但析构旧元素仍需逐个调用,可能比预期慢

真正发挥 deque 价值的典型场景是:滑动窗口、BFS 队列、撤销(支持从头加新操作、从尾撤回)——这些都天然契合“两端活跃、中间静态”的访问模式。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

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

646

2023.08.02

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

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

553

2024.08.29

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

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

173

2025.08.29

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

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

205

2025.08.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

404

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

584

2023.08.10

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

98

2026.02.06

java多线程方法汇总
java多线程方法汇总

本专题整合了java多线程面试题、实现函数、执行并发相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.02.06

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

644

2026.02.06

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.4万人学习

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

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