数据结构_study(三)

news2024/9/17 9:23:51

先进后出,LIFO(last in first out),只能在表尾做插入删除操作的线性表

栈顶:允许插入和删除的一端
栈底:最先进栈
空栈:没有数据元素

压栈、入栈:插入操作
弹栈、出栈:删除操作

只限制插入删除的位置,不限制进出的时间
1、2、3依次进栈
出栈次序

  • 1,2,3进,3,2,1出,321
  • 1进1出,2进2出,3进3出,123
  • 1、2进,2、1出,3进3出,213
  • 1进,1出、2、3进,3、2出,132
  • 1、2进,2出,3进3出,1出,231

抽象数据类型

Stack

Data:相同类型,相邻元素有前驱和后继

Operation:
InitStack(*S) : 初始化操作,建立一个空栈S。
DestroyStack(*S) : 若栈存在,则销毁它。
ClearStack(*S) : 将栈清空。
StackEmpty(S) : 若栈为空,返回true,否则返回false。
GetTop(S, * e) : 若栈存在且非空,用e返回S的栈顶元素
Push(*S, e) : 若栈S存在,插入新元素e到栈S中并成为栈顶元素
Pop(*S, *e) : 删除栈S中栈顶元素,并用e返回其值。
StackLength(S) : 返回栈S的元素个数。

顺序栈

0做栈底,top做栈顶
top <= StackSize-1
空栈 top<0

存取定位方便

出入栈

出栈,判空,获取要删除的元素,top–
入栈,判满,top++,插入新元素

时间复杂度O(1)
在这里插入图片描述

两栈共享空间

一个数组,存两个栈
栈底在数组两端,0、n-1
向中间靠拢,top1、top2
栈空:top1=-1,top2=n
栈满:top1+1=top2

两个相同数据类型栈的空间需求有相反关系
在这里插入图片描述

链栈

链栈:栈的链式结构
栈顶放在头部,头指针做栈顶指针
不需要头结点
不会栈满、在内存中找任意空闲位置,长度无限制,不会空间浪费
空栈:top=NULL

每个元素都有指针域,增加内存开销

出入栈

时间复杂度O(1)
在这里插入图片描述

应用

递归

递归函数:直接或间接调用自己的函数

至少有一个条件满足时递归不再进行,不再引用自身而是返回值退出

迭代:循环结构
递归:选择结构

优点:方便理解
缺点:递归会建立函数副本,耗费大量时间和内存

前行阶段(存储数据):每一层递归的函数局部变量,参数值,返回地址压入栈中
退回阶段(恢复数据):弹出位于栈顶的局部变量,参数值,返回地址,返回调用该层,执行代码的其余部分

前行和退回逆序

斐波那契数列

相邻两项之和,构成后一项
n=0;F(n)=0
n=1;F(n)=1
n>1;F(n)=F(n-1)+F(n-1)
在这里插入图片描述

四则运算表达式

中缀转后缀
后缀出结果

中缀转后缀

中缀表达式 9+(3-1)*3+10/2

从左到右遍历中缀表达式
数字输出
符号,判断其与栈顶元素的优先级,
右括号依次出栈,去掉左括号并输出
优先级低则依次出栈并输出,把当前符号进栈
在这里插入图片描述

后缀(逆波兰)

后缀表达法:不需要括号,所有的符号在运算数字的后面出现

后缀表达式 9 3 1 - 3 * + 10 2 / +

从左往右遍历后缀表达式的每个数字和符号
数字进栈
遇到符号,栈顶两个数字出栈,计算结果进栈
在这里插入图片描述

队列

先进先出,FIFO(First In First Out),一端插入,另一端删除的线性表

队尾:允许插入的一端
队头:允许删除的一端

排队
在这里插入图片描述

抽象数据类型

Queue

Data:相同类型,相邻元素有前驱和后继

Operation:
InitQueue(*Q) : 初始化操作,建立一个空队列Q。
DestroyQueue(*Q) : 若队列Q存在,则销毁它。
ClearQueue(*Q) : 将队列Q清空。
QueueEmpty(Q) : 若队列Q为空,返回true,否则返回false。
GetHead(Q, * e) : 若队列Q存在且非空,用e返回队列Q的队头元素。
EnQueue(*Q, e) : 若队列Q存在,插入新元素e到队列Q中并成为队尾元素。
DeQueue(*Q, * e) : 删除队列Q中队头元素,并用e返回其值。
QueueLength(Q) : 返回队列Q的元素个数

顺序队列

1、队头在下标为0位置
入队(插入)操作:在队尾追加,不需要移动,时间复杂度O(1)
出队(删除)操作:队列所有元素都向前移动,保证队头(下标为0)元素不为空,时间复杂度O(n)

2、队头不固定
front指向队头
rear指向队尾元素的下一个位置
空队列:front=rear
假溢出:rear已经到数组末尾,但数组还有空闲位置
在这里插入图片描述

循环队列

头尾相连的顺序结构的队列

由于空队列和满队列都是rear==front
所以定义为:当数组中只剩一个空闲元素时,队列满

判满:(rear+1)%QueueSize==front
队列长度:(rear-front+QueueSize)%QueueSize

时间复杂度O(1)
提前占用空间,数组溢出\空间浪费
在这里插入图片描述

链队列

链队列尾进头出线性单链表
队头指向头结点,负责删除
队尾指向终端结点,负责插入
空队列:front和rear都指向头结点

时间复杂度O(1),申请释放结点->时间开销
指针域->空间开销,但不需要提前固定长度,用多少占多少不会浪费空间
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1963750.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ubuntu20复现NBV探索

官网代码 后退地平线下一个最佳景观规划师 这个代码有些久远&#xff0c;issue里面有人已经在ubuntu20里面使用了3dmr&#xff0c;但是他那个代码我也运行不成功&#xff0c;docker网络一直也不佳&#xff0c;所以还是自己重新修改源码靠谱。 最终实现的代码等有时间上传到gi…

Day26 | 贪心算法 134. 加油站 135. 分发糖果 860.柠檬水找零 406.根据身高重建队列

语言 Java 134. 加油站 题目链接&#xff1a;加油站 题目 在一条环路上有 n 个加油站&#xff0c;其中第 i 个加油站有汽油 gas[i] 升。 你有一辆油箱容量无限的的汽车&#xff0c;从第 i 个加油站开往第 i1 个加油站需要消耗汽油 cost[i] 升。你从其中的一个加油站出发…

【每日一题】【map和set】RC-v7 熊猫血 C++

2024 睿抗机器人开发者大赛CAIP-编程技能赛-高职组&#xff08;省赛&#xff09; RC-v7 熊猫血 题目描述 在“一年一度喜剧大赛”上有一部作品《少爷和我》&#xff0c;讲的是霸道管家龙傲天和憨厚少爷刘波的故事。管家有着霸总文学主人公所有的毛病&#xff0c;包括会咳出熊…

服务运营 | NRL:疫苗供应链优化建模:综述与未来机遇(上)

编者按&#xff1a; 本次推文将解读近期发表在Naval Research Logistics中的Optimization modeling for pandemic vaccine supply chain management: A review and future research opportunities一文。这篇文章总结与反思了大流行时期的疫苗供应链管理&#xff0c;具体包括疫…

C#基于SkiaSharp实现印章管理(5)

印章中最常见的特殊形状通常是五角星&#xff0c;空心、实心的都可能存在&#xff0c;本文学习并实现在印章内部绘制五角星形状。   百度五角星的绘制方法&#xff0c;主要分为三种&#xff1a;   1&#xff09;五角星各点坐标固定&#xff0c;直接调用编程语言的绘制线条或…

线性结构、线性表、顺序表、链表、头插法、尾插法、中间插入或删除一个节点

梳理几个名词&#xff1a; 逻辑地址&#xff1a;就是说是第几个元素。 物理地址&#xff1a;也就是存储地址&#xff0c;在计算机里具体存放的位置。 线性表的存储结构分为&#xff1a; &#xff08;1&#xff09;顺序存储结构&#xff1a;将数据依次存储在连续的整块物理空…

综合项目部署——eleme前端部署(eighteen day)

显示没有空格没有注释的内容&#xff1a; [rootstatic-server ~]# grep -Ev "#|^$" /usr/local/nginx/conf/nginx.conf 1、多虚拟主机的配置 [rootstatic-server ~]# vim /usr/local/nginx/conf/nginx.conf [rootstatic-server ~]# /usr/local/nginx/sbin/nginx #启…

如何破解绩效管理的难题?

绩效管理的核心问题 &#x1f4bc; 在现代企业运营中&#xff0c;绩效管理一直被视为提升工作效率和实现公司战略目标的重要手段。然而&#xff0c;实际操作中&#xff0c;我们经常会遇到一系列棘手的问题&#xff0c;这些问题不仅影响了绩效管理的有效性&#xff0c;还常常让…

winform程序中拷贝文件夹最快速方法

1、先将一个项目的文件夹拷贝到另一个项目的目录下 下图将ParameterSetting文件夹拷贝到Datalib文件夹下 2、直接复制该文件&#xff0c;然后到vs界面去粘贴 复制ParameterSetting文件夹&#xff0c;然后在Datalib项目这里鼠标右键单击&#xff0c;然后点击“粘贴”&#xff0…

机器学习(五) -- 无监督学习(2) --降维2

系列文章目录及链接 上篇&#xff1a;机器学习&#xff08;五&#xff09; -- 无监督学习&#xff08;2&#xff09; --降维1 下篇&#xff1a; 前言 tips&#xff1a;标题前有“***”的内容为补充内容&#xff0c;是给好奇心重的宝宝看的&#xff0c;可自行跳过。文章内容被…

《动手做科研》06. 如何产生新的研究想法

地址链接:《动手做科研》06. 如何产生新的研究想法 欢迎加入我的知识星球&#xff0c;定期分享AI论文干货知识&#xff01; 导读: 提出好的研究想法是相当困难的&#xff0c;特别是当你刚接触一个领域时——这需要对文献中的空白有所了解。然而&#xff0c;产生研究想法的过程可…

数学建模--智能算法之模拟退火算法

目录 算法原理 应用场景 实现方法 代码示例&#xff1a; MATLAB&#xff1a; Python&#xff1a; 总结 模拟退火算法在数学建模中的具体应用案例有哪些&#xff1f; 如何选择模拟退火算法的参数&#xff08;如初始温度、冷却率等&#xff09;以优化求解过程&#xff1…

根据json构建uml类图代码工具实现

文章目录 1.UML简介1.1 什么是UML建模1.2 使用UML建模的好处 2.当前UML在研发场景下痛点3.UML工具的优化实现3.1 json结构设计3.2 json类图解析器实现3.3 在线uml类图渲染实现3.3.1 前端渲染页面3.3.2 后端数据接口 3.4 在线渲染效果 4. 总结 【摘要】本文介绍UML基本概念及相关…

Linux中安装C#的.net,创建运行后端或控制台项目

安装脚本命令&#xff1a; 创建一个sh文件并将该文件更改权限运行 sudo apt update wget https://packages.microsoft.com/config/ubuntu/20.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb sudo dpkg -i packages-microsoft-prod.deb sudo apt-get upd…

科普文:Spring Cloud Alibaba在GraalVM上的性能测试

GraalVM 介绍 GraalVM概述 - Spring Cloud Alibaba官网 科普文&#xff1a;GraalVM简介-CSDN博客 科普文&#xff1a;OpenJDK vs. GraalVM vs. Amazon Corretto性能测试-CSDN博客 科普文&#xff1a;【方向盘】OpenJDK生态圈-CSDN博客 科普文&#xff1a;Oracle JDK收费后…

【32单片机篇】项目:实时时钟

一、项目需求 1. OLED屏幕显示当前时间、日期、闹钟等信息&#xff1b; 2. 正常模式下&#xff0c;按下 KEY1 &#xff0c;进入时间设置模式&#xff0c;此时按下 KEY2 则可以循环跳转修改秒、分、时、日、月、年&#xff1b; 3. 时间设置模式下&#xff0c;KEY3 增加数值&…

【Redis】如何利用 Redis 实现一个分布式锁?

&#x1f44f;大家好&#xff01;我是和风coding&#xff0c;希望我的文章能给你带来帮助&#xff01; &#x1f525;如果感觉博主的文章还不错的话&#xff0c;请&#x1f44d;三连支持&#x1f44d;一下博主哦 &#x1f4dd;点击 我的主页 还可以看到和风的其他内容噢&#x…

【优秀python算法设计】基于Python网络爬虫的今日头条新闻数据分析与热度预测模型构建的设计与实现

1 绪论 1.1 背景与意义 随着互联网的快速发展和移动互联技术的普及&#xff0c;作为新兴的资讯平台&#xff0c;今日头条成为了用户获取新闻资讯、时事热点和个性化推荐的重要渠道。大量用户在今日头条上浏览、阅读并产生热度&#xff0c;使得今日头条成为了观察舆论热点和分…

Csrf复习(pikachu靶场和防御手段)

CSRF漏洞简介 CSRF又称跨站请求伪造&#xff0c;是指攻击者在用户登录的状态下&#xff08;浏览器保存了用户的cookie&#xff09;通过伪造恶意url诱导用户点击&#xff0c;借助用户的cookie网站权限&#xff08;冒充用户身份来进行非法操作&#xff0c;对于服务器来说是合法的…

达梦数据库系列—36.分区表

目录 1、分区表的分类 1.1 范围分区表 1.2 List分区表 1.3 哈希分区表 1.4 多级分区表 二级分区 三级分区 2、分区表的维护 2.1 增加分区 2.2 删除分区 2.3 交换分区 2.4 融合分区 3、全局索引和局部索引 1、分区表的分类 范围(range)水平分区&#xff1a;对表中…