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 小时前
AI 自动化测试探索(二):Chrome-devtools MCP
人工智能·e2e·aigc
冬奇Lab9 小时前
Workflow 系列(02):设计范式——四层架构、三种 Context 传递模式与确认门设计
人工智能·agent·工作流引擎
冬奇Lab9 小时前
每日一个开源项目(第145篇):Trellis - 把项目记忆、规范和任务上下文持久化进代码仓库
人工智能·开源·资讯
有道AI情报局9 小时前
Harness即产品
人工智能·agent
罗西的思考10 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
IT_陈寒12 小时前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端
笃行35012 小时前
从零到上线:用 EdgeOne Makers + CodeBuddy 搭一个「对账核对员」AI Agent
人工智能
用户68563262086912 小时前
Claude Code 乱猜字段名?我给它写了一个"数据库查询约束 Skill"
人工智能
你_好12 小时前
# 给你的产品嵌入一个「会操作界面的 AI 助手」
人工智能
ShallWeL12 小时前
【机器学习】(3)—— 线性回归:梯度下降
人工智能·机器学习