34_数据结构_栈

一、栈的基本概念

1. 栈的定义

(1) 栈的逻辑结构

a. 线性表的特例
i. 只允许在一端插入和删除
⓵ 栈顶与栈底

2. 栈的特点

(1) 后进先出

a. LIFO 结构

i. 最后进入的元素最先被访问

二、栈的数学表示

1. 栈的状态表示

(1) 栈的序列形式

KaTeX parse error: Expected 'EOF', got '&' at position 4: &̲emsp; &ems...

其中 s1s_1s1 为栈底,sns_nsn 为栈顶

2. 栈的基本操作

(1) 入栈

KaTeX parse error: Expected 'EOF', got '&' at position 4: &̲emsp; &ems...

(2) 出栈

KaTeX parse error: Expected 'EOF', got '&' at position 4: &̲emsp; &ems...

三、栈的存储结构

1. 顺序栈

(1) 基于数组实现

a. 栈顶指针 top

i. top = -1 表示空栈

(2) 代码结构

/*

* Allman 风格

*/

KaTeX parse error: Expected 'EOF', got '&' at position 4: &̲emsp; &ems...

2. 链式栈

(1) 基于链表实现

a. 栈顶为链表头结点

i. 入栈为头插法

⓵ 出栈为删除头结点

四、栈的时间复杂度分析

1. 基本操作

(1) 入栈

a. 顺序栈(未满):O(1)O(1)O(1)

b. 链式栈:O(1)O(1)O(1)

(2) 出栈

a. 顺序栈(非空):O(1)O(1)O(1)

b. 链式栈:O(1)O(1)O(1)

2. 栈的扩容

(1) 动态顺序栈

a. 均摊分析

i. 均摊时间复杂度为 O(1)O(1)O(1)

五、栈的应用场景

1. 函数调用栈

(1) 递归函数的实现

a. 每次调用压入栈帧

i. 返回时弹出栈帧

2. 表达式求值

(1) 中缀转后缀

a. 运算符优先级比较

i. 使用栈临时存储运算符

(2) 后缀表达式求值

a. 遇到操作数入栈

b. 遇到运算符弹出两个操作数

3. 括号匹配

(1) 算法流程

a. 左括号入栈

b. 右括号与栈顶匹配

i. 匹配成功则弹出,否则报错

六、栈的常见问题与扩展

1. 共享栈

(1) 两个栈共享一个数组

a. 栈底分别在数组两端

i. 栈顶向中间移动

2. 栈的溢出与下溢

(1) 上溢

a. 顺序栈满时继续入栈

(2) 下溢

a. 空栈时进行出栈操作

3. 栈与队列的对比

(1) 栈:LIFO

(2) 队列:FIFO

相关推荐
AI医影跨模态组学2 小时前
Adv Sci 复旦大学附属中山医院宋志坚&复旦大学上海肿瘤医院黄丹等团队:基于基础模型的多模态深度学习用于结直肠癌不完整模态的预后预测
人工智能·深度学习·论文·医学·医学影像
爱码驱动2 小时前
文件操作和IO
java·开发语言·io·文件操作
重生之我要成为代码大佬2 小时前
神经网络基础
人工智能·深度学习·神经网络
坊钰2 小时前
Java 反射机制
java·开发语言
cxr8282 小时前
龙虾长程任务测试 —— 撰写零人公司自动化运营实践研究报告
运维·人工智能·自动化·openclaw
key_3_feng2 小时前
PolarDB for AI RAG系统建设方案
人工智能·polardb
mit6.8242 小时前
生成式推荐GR4AD
人工智能
网络工程小王2 小时前
【提示词工程和思维链的讲解】学习笔记
人工智能·笔记·学习
单片机学习之路2 小时前
【Python】输入print函数
开发语言·前端·python