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

std::deque(double-ended queue)是C++标准库中支持两端高效插入和删除的序列容器,底层通常以分段连续空间实现,兼顾了vector的随机访问和list的部分动态性。它不保证内存整体连续,但支持O(1)的头尾操作和O(1)的随机访问(下标/迭代器),适合频繁在首尾增删、又需要按索引读写的场景。
包含头文件 #include
std::deque<int> dq;</int>
std::deque<int> dq(5); // 元素全为0</int>
std::deque<int> dq(5, 42); // 5个42</int>
std::deque<:string> dq{"a", "b", "c"};</:string>
std::deque<int> dq2 = dq1;</int> 或 std::deque<int> dq2 = std::move(dq1);</int>
所有操作均在头尾保持常数时间复杂度(摊还),中间插入/删除仍是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循环、迭代器遍历,也提供常见容量接口:
立即学习“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()(清空,但不释放内存)std::deque<t>(dq).swap(dq);</t> —— 利用临时对象交换来收缩内存(注意:deque的shrink_to_fit不是标准要求,多数实现不支持)deque不是万能替代vector或list,需结合使用场景判断:
&dq[0] 到 &dq[dq.size()-1] 不一定可作C数组用基本上就这些。用好deque的关键是明确“我是否真需要在开头高效操作”,而不是因为名字带“队列”就默认选用它。
以上就是C++如何使用std::deque双端队列?(容器用法)的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号