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

C++ queue队列容器用法_C++ queue基本操作与应用场景

穿越時空
发布: 2025-11-27 16:05:09
原创
965人浏览过
C++中的queue是STL提供的FIFO容器适配器,用于顺序处理数据。1. 需包含头文件<queue>,支持push、pop、front、back、empty和size操作;2. 仅允许队尾入队、队首出队,不支持随机访问;3. 常用于BFS、任务调度、缓冲区管理和二叉树层序遍历等场景。

c++ queue队列容器用法_c++ queue基本操作与应用场景

在C++中,queue 是标准模板库(STL)提供的一个容器适配器,用于实现先进先出(FIFO, First In First Out)的数据结构。它常用于需要按顺序处理数据的场景,比如任务调度、广度优先搜索(BFS)等。

queue的基本定义与头文件

使用 queue 需要包含头文件 <queue>

#include <queue>
using namespace std;

定义一个 queue 的语法如下:

queue<int> q; // 存储整数的队列
queue<string> qstr; // 存储字符串的队列
queue<Node> qnode; // 存储自定义结构体的队列

queue的基本操作

queue 只允许在队尾插入元素,在队首删除元素,主要支持以下几种操作:

Spacely AI
Spacely AI

为您的房间提供AI室内设计解决方案,寻找无限的创意

Spacely AI 67
查看详情 Spacely AI

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

  • push(val):在队尾插入一个元素。
  • pop():删除队首元素(不返回值)。
  • front():返回队首元素的引用。
  • back():返回队尾元素的引用。
  • empty():判断队列是否为空,返回 bool 值。
  • size():返回队列中元素个数。

示例代码:

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

q.pop(); // 移除队首
cout << "新队首: " << q.front() << endl; // 输出 20

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

常见应用场景

1. 广度优先搜索(BFS)
在图或树的遍历中,BFS 使用 queue 来逐层访问节点。每次从队列取出一个节点,将其未访问的邻居加入队列。

2. 任务调度
系统中多个任务需要按提交顺序执行时,可用 queue 管理任务队列,保证公平性。

3. 缓冲区管理
如网络数据包接收、打印任务队列等,数据先到先处理,适合用 queue 实现缓冲机制。

4. 层序遍历二叉树
借助 queue 实现二叉树的层序输出,每一层节点依次入队出队。

注意事项

queue 不支持随机访问,不能使用下标操作(如 q[0]);
仅能通过 front() 和 back() 访问两端元素;
pop() 操作不返回值,需先调用 front() 获取值再 pop。

基本上就这些。掌握 queue 的基本操作和典型用途,能有效提升算法实现效率,尤其在涉及顺序处理和层次遍历的问题中非常实用。

以上就是C++ queue队列容器用法_C++ queue基本操作与应用场景的详细内容,更多请关注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号