当前位置: 首页 > news >正文

数据结构(长期更新)第7讲:栈

数据结构(长期更新)

第7讲:栈

      跟着潼心走,轻松拿捏C语言,困惑通通走,一去不回头~欢迎开始今天的学习内容,你的支持就是博主最大的动力博主主页:潼心1412o-CSDN博客


目录

数据结构(长期更新)

第7讲:栈

7.1 前言

7.2 概念性质

7.3 实现方式/底层结构

7.4 基本操作

7.5 栈的应用(算法题解)

7.5.1 有效的括号


7.1 前言

上节课我们学习了双向链表,至此我们一共学习了两种线性表。顺序表和链表在使用上各有优劣。在需要批量存储,频繁调用时首选顺序表;在需要快速插入删除数据,根据需要增容时优先使用链表。今天我们来介绍一种全新的线性表结构——栈。

7.2 概念性质

栈是一种特殊的线性表,他只能在一端插入删除数据,具有后进先出的特性LIFO(LAST IN FIRST OUT)

栈顶:进行插入删除操作的一端

栈底:另一端

压栈:栈从栈顶插入数据叫做压栈、进栈、入栈

出栈:栈的删除数据

7.3 实现方式/底层结构

在实际使用中,我们一般选择数组作为栈的底层结构

分析:数组或链表哪个更好?

1.时间

时间复杂度首先看看哪一端作栈顶?首选时间复杂度低的一端

对于链表,选头节点作为栈顶,头插头删时间复杂度都为O(1)

对于数组,选取尾部作为栈顶,尾插尾删时间复杂度都为O(1)

2.空间

对于链表,插入一个新节点需要一个datatype,再加一个指针

对于数组,插入一个新数据只需要再开辟一个datatype的空间就ok

很明显,数组在空间上更具优势

7.4 基本操作

//初始化

//入栈---栈顶

//判断栈是否为空

//出栈---栈顶

//取栈顶元素

//获取栈中有效元素个数
 

//栈的销毁
 

7.5 栈的应用(算法题解)

7.5.1 有效的括号

https://leetcode.cn/problems/valid-parentheses/description/


思路:左括号入栈,右括号和栈顶进行匹配,不匹配false,全部完了,剩左括号也false

完整代码如下

需要注意的点:

正确思路:


  好了今天的学习内容就到这里啦,谢谢你的陪伴,我是潼心,下次再见~如果这篇文章对你有帮助的话。请务必给主播一个一键三连,球球了,这对主播很重要~​​​​​​ 

博主主页:潼心1412o-CSDN博客

http://www.dtcms.com/a/597190.html

相关文章:

  • 企业网站设计过程中wordpress 侧边栏插件
  • 【20251028】linux上面拉取仓库,以Ubuntu虚拟机为例
  • 第8节 计算机病毒概念的正式化和安全行业的兴起
  • 使用C#代码在 PDF 中创建目录
  • NAT基础原理
  • 多粒子模型--交通堵塞2
  • 用AI训练数据,预测房地产价格走势(Python版)
  • Rust:泛型
  • [CSP-X2025山东小学组T4]勇者斗恶龙
  • 基于单片机的多模式智能洗衣机设计
  • 【java阶段练习】----- 学生管理系统
  • 高校网站如何建设论文外国网站怎么做
  • portfolio做网站台州做网站需要多少钱
  • 网站名称 规则装修设计培训机构
  • Dify工作流如何用“拖拉拽”重构我们的自动化测试体系?
  • 【Docker】基础
  • AI应用开发的架构哲学:框架、平台与定制的协同(ComfyUI+cnb+云存储)
  • MySQL快速入门——索引
  • 舆情处置的技术实现:Infoseek 如何用 AI 重构 “识别 - 研判 - 处置” 全链路
  • gRPC vs RPC 高频面试题
  • 淘宝联盟推广网站怎么做什么是搜索引擎
  • 扬州住房城乡建设局网站设计画册
  • 在线视频网站a做免费下载中山精品网站建设价位
  • LangFlow 节点(Node)
  • Linux设置系统同步时间
  • 花垣网站建设一台主机做两个网站
  • 生成模型技术宇宙:从VAE到世界模型,揭示AIGC核心引擎
  • 网站建设中魔板免费扑克网站代码
  • 股指期货的收益和风险大吗?
  • 第12章 测试编写