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

相关推荐
你疯了抱抱我7 小时前
【STM32】使用 STM32CubeMX 生成项目,LED测试;上位机:STM32F411CEU6
stm32·单片机·嵌入式硬件
2301_773643627 小时前
ceph池
开发语言·ceph·python
两年半的个人练习生^_^7 小时前
JMM 进阶:彻底理解 CAS 实现原理
java·开发语言
wuminyu7 小时前
Java锁机制之park和unpark源码剖析
java·linux·c语言·jvm·c++
梦梦代码精7 小时前
为什么这个开源的AI平台会火?有点东西。。。
人工智能·算法·机器学习·docker·开源
大模型真好玩7 小时前
智能体从入门到精通:6个必学GitHub开源项目
人工智能·agent·deepseek
半个烧饼不加肉7 小时前
JS 底层探究-- 事件循环
开发语言·前端·javascript
随意起个昵称7 小时前
线性dp-综合刷题1(Not Alone)
算法·动态规划
源图客8 小时前
Aitoearn:OPC(一人公司)的AI内容智能体
人工智能·dreamweaver