首页 > 后端开发 > C++ > 正文

C++如何使用queue(队列)_C++标准队列容器的用法示例

下次还敢
发布: 2025-11-11 08:11:12
原创
417人浏览过
答案:queue是C++ STL中遵循FIFO原则的容器适配器,需包含<queue>头文件,常用操作包括push、pop、front、back、empty和size,适用于BFS和任务调度等场景。

c++如何使用queue(队列)_c++标准队列容器的用法示例

queue 是 C++ 标准模板库(STL)中的一种容器适配器,遵循先进先出(FIFO, First In First Out)的原则。它常用于需要按顺序处理数据的场景,比如广度优先搜索(BFS)、任务调度等。下面介绍如何在 C++ 中正确使用 std::queue

包含头文件与基本定义

要使用 queue,必须包含对应的头文件:

// 包含 queue 头文件
#include <queue>

// 使用标准命名空间
using namespace std;

定义一个空队列的基本语法如下:

queue<int> q; // 存储整数的队列
queue<string> qs; // 存储字符串的队列

常用成员函数说明

queue 提供了几个核心操作函数,用于添加、删除和访问元素:

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

智标领航
智标领航

专注招投标业务流程的AI助手,智能、高效、精准、易用!

智标领航 117
查看详情 智标领航
  • push(value):在队尾插入一个元素
  • pop():移除队首元素(不返回值)
  • front():获取队首元素的引用
  • back():获取队尾元素的引用
  • empty():判断队列是否为空,返回 bool
  • size():返回队列中元素个数

基本操作示例代码

以下是一个完整的使用示例:

#include <iostream>
#include <queue>
using namespace std;

int main() {
queue<int> q;

// 入队操作
q.push(10);
q.push(20);
q.push(30);

cout << "队首元素: " << q.front() << endl; // 输出 10
cout << "队尾元素: " << q.back() << endl; // 输出 30

cout << "队列大小: " << q.size() << endl; // 输出 3

// 遍历并出队所有元素
while (!q.empty()) {
cout << "当前队首: " << q.front() << endl;
q.pop(); // 移除队首
}

if (q.empty()) {
cout << "队列已空" << endl;
}

return 0;
}

输出结果为:

队首元素: 10
队尾元素: 30
队列大小: 3
当前队首: 10
当前队首: 20
当前队首: 30
队列已空

注意事项与常见用法

queue 不支持随机访问,不能使用下标操作符 []。如果需要频繁访问中间元素,应考虑使用 vector 或 deque。

  • 调用 front()back() 前务必确保队列非空,否则行为未定义
  • pop() 只删除元素,不返回值。如需获取并删除队首,应先调用 front() 再调用 pop()
  • queue 默认基于 deque 实现,也可指定其他底层容器(如 list)
queue<int, list<int>> q_list; // 使用 list 作为底层容器

基本上就这些。掌握 push、pop、front 和 empty 就能应对大多数使用场景。实际编程中注意判空即可避免运行时错误。

以上就是C++如何使用queue(队列)_C++标准队列容器的用法示例的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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