当前位置: 首页 > news >正文

C++中栈是如何实现,以及常用的栈函数都有哪些

什么是栈?

是一种特殊的数据结构,它是一种按照 Last-In-First-Out (LIFO) 访问模式存储和访问数据的特殊结构。 换句话说,栈中的最后一个元素将成为最先出栈的元素,这也意味着新增加的元素在栈的顶部,而出栈的元素在栈底部。 因此,放入栈里的最后一个元素,将会成为最后出栈的元素。

在C++中栈是如何被实现的

C++ 中的栈被实现为容器适配器 “adaptor" stack,它使用底层容器来储存元素,如vector、deque、list等容器。 使用者只能访问栈中的顶部元素,但不能直接使用底层容器的索引访问容器中的元素。因此,会提供一些常用的操作函数,来代替用户分别对底层容器的 push/pop 和 top 操作。 如:push 用来向栈放入新的元素, pop 用来从栈中 Popular 元素, top 用来访问当前顶部元素, empty/size 用来查看栈内元素的个数等等。

适配器(adaptor)是标准库的一个通用概念,本质上,适配器是一种机制,它能使某种事物的行为看起来像另一种事物一样。
一种容器适配器接受一种已有的容器,使其行为看起来像一种不同的类型。

在这里stack接受一种顺序容器,使其行为看起来像stack一样。

C++ 中的栈函数

在 C++ 中,用户可以使用标准库中的 stack 里的函数,以实现特定的栈操作,可用的函数如下:

  • empty():该函数返回一个布尔值,表明栈是否为空。

  • push():该方法将元素添加到栈顶。

  • pop(): 该方法移除栈顶的元素。

  • top(): 该方法返回栈顶的对象,但不会移除它。

  • size(): 该方法返回栈中元素的数量。

http://www.lryc.cn/news/30835.html

相关文章:

  • 我就不信你还不懂HashSet/HashMap的底层原理
  • Qt中调用gtest进行单元测试及生成覆盖率报告
  • ChatGPT vs Bard 背后的技术对比分析和未来发展趋势
  • 搜索引擎的设计与实现
  • 动态规划之买卖股票问题
  • MySQL学习笔记之子查询
  • HCIP-5OSPF域内域间外部路由学习笔记
  • 【编程实践】简单是好软件的关键:Simplicity is key to good software
  • Python|贪心|数组|二分查找|贪心|数学|树|二叉搜索树|在排序数组中查找元素的第一个和最后一个位置|计数质数 |将有序数组转换为二叉搜索树
  • 操作系统——15.FCFS、SJF、HRRN调度算法
  • 如何防止用户打开浏览器开发者工具?
  • C语言-基础了解-12-C数组
  • RocksDB 架构
  • MVVM和MVC的区别
  • c++11 标准模板(STL)(std::unordered_map)(三)
  • OpenGL环境配置
  • SpringCloud之 Eureka注册中心
  • Linux入门篇-用户管理
  • G. Special Permutation(构造)
  • QML动态对象管理
  • cmake入门03 -自定义find外部库
  • Dubbo源码解析-——服务导出
  • vue+django+neo4j 基于知识图谱红楼梦问答系统
  • 2023年全国最新食品安全管理员精选真题及答案13
  • Keychron K7 Pro 轻薄矮轴机械键盘开箱体验
  • 加油站ai视觉识别系统 yolov7
  • 【电子学会】2022年12月图形化二级 -- 绘制风车
  • 【golang/go语言】Go语言代码实践——高复用、易扩展性代码训练
  • [数据结构与算法(严蔚敏 C语言第二版)]第1章 绪论(学习复习笔记)
  • 05_Pulsar的主要组件介绍与命令使用、名称空间、Pulsar的topic相关操作、Pulsar Topic(主题)相关操作_高级操作、