queue是FIFO容器,仅支持尾插头删,适用于BFS等场景;deque支持双端操作且可随机访问,适合滑动窗口和频繁首尾插入,功能更灵活但应根据需求选择。
在C++中,queue 和 deque 是两种常用的容器适配器,适用于不同场景下的数据操作需求。它们都定义在 头文件中(deque 需要 ),使用时需包含对应头文件。
queue 是一种先进先出(FIFO)的数据结构,只允许在队尾插入元素,在队首删除元素。
常用操作包括:
示例代码:
#include
std::queueq;
q.push(10);
q.push(20);
if (!q.empty()) {
std::cout << q.front() << std::endl; // 输出 10
q.pop(); // 移除 10
std::cout << q.front() << std::endl; // 输出 20
}
deque(double-ended queue)支持在头部和尾部高效地插入和删除元素,功能比 queue 更灵活。
它兼具 vector 和 queue 的特点,可以在两端进行操作。
常用操作有:
示例:
#include
std::dequedq;
dq.push_back(1);
dq.push_front(0);
dq.push_back(2);
for (int i = 0; i < dq.size(); ++i) {
std::cout << dq[i] << " "; // 输出 0 1 2
}
虽然 deque 功能更全,但选择应根据使用场景决定。
常见用途:
基本上就这些,合理选择容器能提升代码可读性和效率。