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

栈:只允许在一端进行插入或删除操作的线性表

一、重要术语:

栈顶、栈底、空栈

二、线性表的基本操作

三、栈的相关操作:

把线性表中的list改成stack

                        insert改成 push

                        delete 改成 pop

总结:“后进先出”

四、顺序栈:

缺点:栈的大小不可变

1.定义:

2.初始化:判断栈顶元素是否为空只需要s.top==-1是否成立

S.top = S.top + 1

>>>>>>> top指针加一

>>>>>>>>

S.data[S.top] = x 

>>>>>>>数据存入

>>>>>>>>top指针始终指向栈顶元素

等价代换式

应该是让top加一,再让其指向数据元素

而不能写成S.top++

否则会变成 先指向数据元素再加一


五、出栈操作:S.top--

六、读栈操作:

读栈>>>>>s.top++和--s.top要进行记忆

七、共享栈:

总结:

总结:

对于pop操作和push操作

在一开始要加入元素时候,指针指向的是栈以外的区域,并不是栈内,所以要先++指针,再进行插入操作

而对于pop弹出元素时候,指针一开始就指向栈顶,所以要先将所指的这个元素进行pop弹出,再进行j-- 操作


http://www.mrgr.cn/news/34514.html

相关文章:

  • MySQL外连接与子查询
  • C语言编译与链接
  • 字母与符号检测系统源码分享
  • GBase 8s 安装手册
  • 9.23每日作业
  • 【C#生态园】从容面对.NET性能挑战:全面解析多种性能监控工具
  • yolov8使用强数据增强
  • 深度学习:卷积神经网络CNN
  • 自定义类型
  • 全国职业院校技能大赛(大数据赛项)-平台搭建Spark、Scala笔记
  • Docker快速搭建PostgreSQL15流复制集群
  • Openpyxl 插入数据添加数据
  • Python人工智能之路 - 第一篇 : 你得会点儿Python基础
  • Pointnet++改进59:全网首发MogaBlock(2024最新模块)|用于在纯基于卷积神经网络的模型中进行判别视觉表示学习,具有良好的复杂性和性能权衡
  • Kubernetes Pod调度基础
  • 链表练习包括(创建遍历插入删除逆置排序)
  • 常见协议及其默认使用的端口号
  • 全栈开发(二):springBoot3连接mysql数据库
  • Spring Boot | 使用 `@Scheduled`: 定时任务的实现与优化
  • 【论文速看】DL最新进展20240923-长尾综述、人脸防伪、图像分割