数据结构--栈的插入、删除、查找详解

1 栈和队列

1.1 栈和队列的定义和特点
  • 栈:后进先出 队列:先进先出
1.1.1 栈的应用
1.1.2 队列的应用
1.2 栈的定义和特点
1.2.1 栈的相关概念
1.2.1 栈和线性表的区别
1.3 队列的定义和特点
1.4 栈和队列的相关案例
1.4.1 案例一:进制转换 (栈)

例题:

1.4.2 案例二:括号匹配的检验 (栈)

算法思路:

1.4.3 案例三:表达式求值 (栈)

算法思路:

1.4.4 舞伴问题
1.5 栈的表示和操作的实现
1.5.1 栈的抽象数据类型的类型定义
1.5.2 顺序栈的表示和实现
1.5.3 顺序栈的数据类型定义
1.5.4 顺序栈的初始化

注意:

  1. new SElemTypeMAXSIZE 做了什么?
  • new 是C++里的动态内存分配关键字(C语言用 malloc )

  • SElemType 是栈里存的元素类型(比如 int 、 char ,你可以理解成"要存的东西的类型")

  • MAXSIZE 是栈的最大容量(比如100,代表最多存100个元素)

这句话的本质:向系统申请一块连续的、大小为 MAXSIZE 个 SElemType 元素的内存空间,并且返回这块空间的起始地址。

  1. 为什么要把这个地址赋值给 S.base ?

S.base 是栈底指针,它需要指向栈的起始位置。

  • 我们刚用 new 申请了一块连续内存,这块内存就是我们的「栈」

  • 把这块内存的起始地址赋值给 S.base ,就相当于让 S.base 指向了栈的最底部(0号位置)

  • 从此 S.base 就锚定了栈的起点,再也不会变了

  • if (!S.base)

    不是在判断栈空不空,

    是在判断:栈这个"容器"本身有没有被造出来!

1.5.5 顺序栈判断栈是否为空
1.5.6 求顺序栈的长度
1.5.7 清空顺序栈
1.5.8 销毁顺序栈
1.5.9 顺序栈的入栈

注意:

在C/C++中:

  • 如果 if 条件后面没有写大括号 {} ,那么 if 只会控制紧接在它后面的那1条语句

  • 这条语句执行完(或者不执行), if 的控制就结束了,后面的代码不受if影响,一定会执行

1.5.10 顺序栈的出栈
1.5.11 链栈的表示和实现
1.5.12 链栈的初始化
1.5.13 判断链栈是否为空
1.5.14 链栈的入栈
1.5.15 链栈的出栈
1.5.16 取栈顶元素
1.6 栈与递归
1.6.1 递归的定义
  • 递归定义的数学函数
  • 具有递归特性的数据结构
  • 可递归求解的问题
1.6.2 分治法
1.6.3 函数调用过程

例题:

1.6.4 递归的优缺点
  • 方法1:
  • 方法2:
1.6.5 借助栈改写递归的方法
相关推荐
方也_arkling6 小时前
【Java-Day08】static / final / 枚举
java·开发语言
艾莉丝努力练剑6 小时前
【Linux:文件】Ext系列文件系统进阶
linux·运维·服务器·c++·文件系统·文件io·ext
风吹夏回6 小时前
Python 全局异常处理:从“满屏 try-except”到优雅兜底
开发语言·python
Chengbei116 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
eggcode6 小时前
【Qt学习】Linux(ARM架构)在线安装Qt6.x
linux·qt·学习·arm
llz_1126 小时前
web-第一次课后作业
java·开发语言·idea
kkeeper~6 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
小熊Coding6 小时前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
秋96 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
2401_868534787 小时前
论企业网络设计
数据结构