0

0

c++如何使用标准库中的queue和stack 队列和栈的实现【数据结构】

冰火之心

冰火之心

发布时间:2025-12-27 15:25:07

|

432人浏览过

|

来源于php中文网

原创

queue和stack是C++容器适配器,基于deque等容器封装,分别实现FIFO和LIFO语义;queue支持push/pop/front/back,stack支持push/pop/top;均无迭代器、不支持随机访问,且pop不返回值。

c++如何使用标准库中的queue和stack 队列和栈的实现【数据结构】

在 C++ 标准库中,queuestack 是容器适配器(container adapters),不是独立的底层数据结构,而是基于其他容器(如 dequevectorlist)封装而成,提供了受限的接口:只允许在特定位置插入/删除元素,符合队列(FIFO)和(LIFO)的逻辑。

如何使用 std::queue(队列)

std::queue 默认底层使用 std::deque,支持在队尾入队(push)、队首出队(pop),并可通过 front()back() 访问首尾元素。它不提供迭代器,也不能随机访问。

基本用法示例:

  • 包含头文件:#include
  • 声明:例如 std::queue q;(默认基于 deque)
  • 常用操作:
    • q.push(x):将 x 入队(队尾)
    • q.front():访问队首元素(不移除)
    • q.back():访问队尾元素(不移除)
    • q.pop():移除队首元素(不返回值)
    • q.empty()q.size():判断空、获取长度
  • 注意:front()pop() 必须在非空时调用,否则行为未定义;建议先用 empty() 检查

如何使用 std::stack(栈)

std::stack 同样是容器适配器,默认底层也用 std::deque,仅暴露栈顶操作:压栈(push)、弹栈(pop)、访问栈顶(top)。

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

Python v2.4 中文手册 chm
Python v2.4 中文手册 chm

Python v2.4版chm格式的中文手册,内容丰富全面,不但是一本手册,你完全可以把她作为一本Python的入门教程,教你如何使用Python解释器、流程控制、数据结构、模板、输入和输出、错误和异常、类和标准库详解等方面的知识技巧。同时后附的手册可以方便你的查询。

下载

基本用法示例:

  • 包含头文件:#include
  • 声明:例如 std::stack s;
  • 常用操作:
    • s.push(x):x 压入栈顶
    • s.top():访问栈顶元素(不移除)
    • s.pop():移除栈顶元素(不返回值)
    • s.empty()s.size():判空、查大小
  • 注意:top()pop() 都要求栈非空;top() 返回的是引用,可读可写(若元素类型允许)

自定义底层容器(进阶用法)

你可以显式指定底层容器,从而影响性能或内存特性。例如:

  • std::queue> q_list;:用 list 实现 queue(适合频繁插入删除但对缓存不敏感的场景)
  • std::stack> s_vec;:用 vector 实现 stack(连续内存,cache 友好,但扩容有代价)
  • 注意:所选容器必须支持必要操作,比如 queue 要求容器有 push_backpop_front,所以 vector 不能直接用于 queue(缺少 pop_front

常见误区与提醒

初学者容易混淆的点:

  • queuestack 不是“可以遍历的容器”,没有 begin()/end(),也不支持下标访问
  • pop() 系列函数都不返回值——想获取再删除,需先 front()/top(),再 pop()
  • 它们不提供查找、排序、去重等功能,这些需自行处理或换用其他容器(如 vector + 算法)
  • 多线程环境下,标准库容器本身不保证线程安全;如需并发访问,应加锁或使用专用并发结构

掌握这两个适配器的关键是理解“接口限制”背后的意图:让代码更清晰地表达 FIFO 或 LIFO 的业务语义,而不是纠结于底层实现。用对了,能显著提升逻辑可读性和维护性。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

515

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

47

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

187

2025.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

47

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

94

2025.10.23

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

529

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

4

2025.12.22

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

27

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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