码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据结构(郝斌)】03线性结构-栈


    数据结构-栈

    • 什么是栈
    • 静态栈 动态栈
      • 区别:
      • 静态栈
      • 动态栈
    • 操作
    • 栈的标准库操作
    • 动态栈的操作实现
      • 操作
      • void initStack(PSTACK s)
      • void pushStack(PSTACK s,int val)
      • void traverse(PSTACK s)
      • bool popStack(PSTACK s,int *pVal)
      • void clearStack(PSTACK s)
    • 栈的应用(无拓展补充)
      • 函数调用
      • 中断
      • 表达式求值
      • 内存分配
      • 缓冲处理
      • 迷宫

    内存分为静态内存(在栈里分配)和动态内存(在堆里分配)。
    栈和堆表示分配数据的方式。
    栈:静态内存,以压栈和出栈的方式分配内存。
    堆:堆排序的方式分配内存。

    https://blog.csdn.net/zichen_ziqi/article/details/80807989

    什么是栈

    一种可以实现“先进后出”的存储结构。

    静态栈 动态栈

    区别:

    1.静态栈必须提前确定栈的大小(有限的),并且都是连续的.;动态栈可以无限大小(内存够的情况下),并且是不连续的.

    2**.静态栈可以复用顺序表的代码;动态栈可以复用单链表**的代码。

    静态栈

    选择线性表的尾部(头部)作为栈顶,也就是说只能允许在这一端进行操作;相应的在进行出栈操作时也是从线性表的尾部(头部)开始。

    动态栈

    元素之间不连续

    操作

    出栈:栈的删除操作

    压栈:进栈,栈的插入操作

    栈的标准库操作

    头文件: #include< stack > 。定义:stack< int > s;

    s.empty();         //如果栈为空则返回true, 否则返回false;
    s.size();          //返回栈中元素的个数
    s.top();           //返回栈顶元素, 但不删除该元素
    s.pop();           //弹出栈顶元素, 但不返回其值
    s.push();          //将元素压入栈顶
    
    • 1
    • 2
    • 3
    • 4
    • 5

    动态栈的操作实现

    先定义一个节点数据类型结构体,里面有节点值和下一个节点地址两个成员。
    再定义栈的结构体,里面有一个栈顶节点(指向栈顶元素),一个栈尾节点(指向栈尾元素的下一个没有实际含义的)。

    操作

    初始化 initStack(PSTACK)
    栈的插入
    栈的遍历输出
    栈的删除
    栈的清空

    void initStack(PSTACK s)

    定义栈结构体变量,并不意味着栈已经创建好了。此时该对象指向的是垃圾值,
    需要对其初始化(栈尾和栈头指向同一个没有实际含义的节点(栈尾的下一个))。
    造出一个空栈。

    参数:栈指针对象(普通栈对象取地址)
    步骤:
    通过malloc函数动态创建这个空间;
    栈首等于栈尾;
    栈首的下个节点的地址为空。

    在这里插入图片描述

    void pushStack(PSTACK s,int val)

    参数:栈指针对象(普通栈对象取地址)、新节点的数据值
    步骤:
    动态创建一个节点,数据域是数据值,指针域指向原来的栈首。栈首指针域指向新节点。
    在这里插入图片描述

    void traverse(PSTACK s)

    参数:栈指针对象(普通栈对象取地址)
    步骤:
    定义一个指针节点为栈首
    当该节点不为栈尾节点时,输出当前节点数据值。循环输出。
    在这里插入图片描述

    bool popStack(PSTACK s,int *pVal)

    作用:出栈一次,把要出栈的元素存入 pVal形参指向的变量。成功,返回该变量值。失败 false.
    步骤:
    判断是否为空栈
    定义一个节点指向ptop,
    ptop指向该栈顶节点的下一位
    释放 该节点
    赋空该节点
    在这里插入图片描述

    在这里插入图片描述
    测试:
    在这里插入图片描述

    void clearStack(PSTACK s)

    功能:清空栈
    步骤:判断是否为空栈
    定义两个节点p、q,初始一个p指向栈顶,一个q初始为空,即将指向栈顶的下一个节点。
    当p!=栈尾,q指向p的下一个节点。释放p。p等于q。
    在这里插入图片描述

    栈的应用(无拓展补充)

    函数调用

    中断

    表达式求值

    内存分配

    缓冲处理

    迷宫

  • 相关阅读:
    Grafana 系列-统一展示-3-Prometheus 仪表板
    语音合成 - TTS pyttsx3
    6.MySql连接SqlYog
    计算机毕业设计之java+ssm的图书销售管理信息系统
    Ansible 自动化运维工具的使用
    TCP三次握手,四次挥手策略
    从零开始的C++(三)
    Elasticsearch 认证模拟题 - 18
    【正点原子STM32连载】第二十三章 OLED显示实验 摘自【正点原子】MiniPro STM32H750 开发指南_V1.1
    UML六大关系总结
  • 原文地址:https://blog.csdn.net/kin_16/article/details/126274634
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号