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

栈(定义,基本操作,顺序存储,链式存储)

目录

  • 1.栈的定义
    • 1.重要术语
    • 2.特点
  • 2.栈的基本操作
  • 3.栈的顺序存储
    • 1.顺序栈的定义
    • 2.基本操作
      • 1.初始化
      • 2.进栈
      • 3.出栈
      • 4.读栈顶
    • 3.共享栈
  • 4.栈的链式存储

1.栈的定义

栈( Stack)是只允许在一端进行插入或删除操作的线性表
一种受限的线性表,只能在栈顶进行插入删除。

1.重要术语

栈顶:允许插入和删除的一端。
栈底:不允许插入和删除的一端。
空栈:对应线性表的空表。
栈顶元素
栈底元素

2.特点

后进先出:Last In First Out (LIFO)

2.栈的基本操作

  1. InitStack(&S):初始化栈。构造一个空栈S,分配内存空间。
  2. DestroyStack(&L):销毁栈。销毁并释放栈S所占用的内存空间。
  3. Push(&S,x):进栈,若栈S未满,则将x加入使之成为新栈顶。
  4. Pop(&S,&x):出栈,若栈S非空,则弹出栈顶元素,并用x返回。(删除栈顶元素)
  5. GetTop(S,&x):读栈顶元素。若栈S非空,则用x返回栈顶元素。(不删除栈顶元素)
  6. StackEmpty(S):判断一个栈S是否为空。若S为空,则返回true,否则返回false。

n个不同元素进栈,出栈元素不同排列的个数为 1 n + 1 C 2 n n \frac{1}{n+1}C_{2n}^n n+11C2nn
上述公式称为卡特兰(Catalan)数,可采用数学归纳法证明。

3.栈的顺序存储

顺序存储:给各个数据元素分配连续的存储空间,大小为MaxSize*sizeof(ElemType)
静态数组实现,并需要记录栈顶指针。

1.顺序栈的定义

顺序栈的缺点:栈的大小不可变。

在这里插入图片描述

2.基本操作

1.初始化

在这里插入图片描述

2.进栈

在这里插入图片描述

3.出栈

在这里插入图片描述

4.读栈顶

在这里插入图片描述

3.共享栈

两个栈共享同一片内存空间,两个栈从两边往中间增长。

在这里插入图片描述

栈满的条件: top0 + 1 == top1

4.栈的链式存储

本质上用链式存储实现栈就是只允许在单链表的一段进行插入和删除操作。
进栈对应插入操作,出栈对应删除操作。

在这里插入图片描述

进栈/出栈都只能在栈顶一端进行(链头作为栈顶)。

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

相关文章:

  • 在HTML单页面中,使用Bootstrap框架的多选框如何提交数据
  • 当爱好变成职业,会不会就失去了兴趣?
  • 3-知识补充-MVC框架
  • leetcode:141. 环形链表
  • 了解企业邮箱的外观和功能特点
  • 配置阿里云镜像加速器 -docker
  • 11 抽象向量空间
  • 干洗店洗鞋店管理系统app小程序;
  • NOIP2023模拟13联测34 总结
  • Python武器库开发-常用模块之subprocess模块(十九)
  • java验证 Map 的 key、value 是否可以为空
  • 编写MBR主引导记录
  • 从零开始搭建React+TypeScript+webpack开发环境-自定义配置化的模拟服务器
  • python 之字典的相关知识
  • 上下游系统对接的沟通与协作
  • pytest 的使用===谨记
  • Qt 4.8.6 的下载与安装
  • 图形推理 | 判断推理
  • npm的使用
  • Web服务器实战
  • 2021年电工杯数学建模B题光伏建筑一体化板块指数发展趋势分析及预测求解全过程论文及程序
  • pandas教程:Essential Functionality 索引 过滤 映射 排序
  • pyspark连接mysql数据库报错
  • HK WEB3 MONTH Polkadot Hong Kong 火热报名中!
  • “第六十三天”
  • 常用排序算法实现
  • 使用表单登录方法模拟登录通信人家园,要求发送登录请求后打印出来的用户名下的用户组类别
  • Redis 的缓存击穿,穿透,雪崩及其解决方案
  • JWT原理分析——JWT
  • Jprofiler/ VisualVM 定位内存溢出OOM