queue是FIFO容器,仅支持尾插头删,适用于BFS等场景;deque支持双端操作且可随机访问,适合滑动窗口和频繁首尾插入,功能更灵活但应根据需求选择。

在C++中,queue 和 deque 是两种常用的容器适配器,适用于不同场景下的数据操作需求。它们都定义在 <queue></queue> 头文件中(deque 需要 <deque></deque>),使用时需包含对应头文件。
queue 是一种先进先出(FIFO)的数据结构,只允许在队尾插入元素,在队首删除元素。
常用操作包括:
示例代码:
立即学习“C++免费学习笔记(深入)”;
#include <queue><br>std::queue<int> q;<br>q.push(10);<br>q.push(20);<br>if (!q.empty()) {<br> std::cout << q.front() << std::endl; // 输出 10<br> q.pop(); // 移除 10<br> std::cout << q.front() << std::endl; // 输出 20<br>}
deque(double-ended queue)支持在头部和尾部高效地插入和删除元素,功能比 queue 更灵活。
它兼具 vector 和 queue 的特点,可以在两端进行操作。
常用操作有:
示例:
#include <deque><br>std::deque<int> dq;<br>dq.push_back(1);<br>dq.push_front(0);<br>dq.push_back(2);<br>for (int i = 0; i < dq.size(); ++i) {<br> std::cout << dq[i] << " "; // 输出 0 1 2<br>}
虽然 deque 功能更全,但选择应根据使用场景决定。
常见用途:
基本上就这些,合理选择容器能提升代码可读性和效率。
以上就是C++ queue队列常用操作_C++双端队列deque与queue使用技巧的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号