最新要闻
- 环球观察:《庆余年2》又新增七位女角色,金晨出演叶灵儿
- 赛力斯SERES 5出海欧洲市场:德国不限速高速飙到225Km/h
- 颜值超高碾压一众国产!长安启源A07路试:上市就打比亚迪汉
- 宝马5系首获半自动驾驶认证:变道只需看眼后视镜|世界短讯
- 100元记3分!杭州对“加塞”司机开罚 网友:请全国推广 消息
- 广东荔枝价格跌至5年来最低:仅需3、4元一斤
- 街拍,游走在法律和道德边缘
- 世界观热点:6月20日 11:03分 迈普医学(301033)股价快速拉升
- 日系还香吗?新一代本田皓影混动/插混上市:19.99万起要打比亚迪_世界报资讯
- 16.5亿打造!《封神三部曲》第一部7月20上映:预告片发布
- 全脂/低脂可选:特仑苏纯牛奶2.7元/盒大促(商超6元)
- 世界快看点丨微软明确不会涉足VR:市场实在太小
- 红魔8S Pro首发高频版骁龙8 Gen2!170万跑分比骁龙8 Gen3还猛 焦点速讯
- 【全球新要闻】对在建工程“全面体检”
- 最资讯丨失乐园电影迅雷下载 失乐园电影未删减版迅雷下载
- 债市相对更强,股市估值处相对低位-焦点速递
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
天天新资讯:线性结构中的栈、队列和串是怎么回事?
一. 栈
1. 栈的概念
栈 (stack)是一种操作受限的线性表,栈的操作被限定在线性表的尾部进行,栈结构有两个特殊概念:
- 栈顶:栈的尾部被称为栈顶(Top);
- 栈底:另一端固定不动,被称为栈底(Bottom)。
栈中的元素只能先入后出。 最早进入栈的元素所在的位置是栈底,最后进入栈的元素所在的位置是栈顶。数据进入栈的过程叫入栈或压栈,数据从栈中出去的过程叫出栈或弹栈。如下图所示:
(资料图)
2. 栈的实现
在实现上,栈既可以用数组来实现,也可以用链表来实现。用数组实现的栈叫顺序栈或静态栈,用链表实现的栈叫做链式栈或动态栈,这两种实现方式分别如下图所示:
3. 栈的操作
刚刚给大家介绍了栈顶和栈底的概念,栈的操作就和这两个概念有关。栈一般只有两个操作:入栈和出栈。
3.1 入栈
入栈操作就是把元素(数据)放入到栈中,入栈操作又称压栈,有时也称之为push操作,均表示入栈操作含义。需要注意的是,根据栈结构的特点,入栈只允许从栈顶放入元素,进入栈的新元素会在最上方,成为栈顶。
对于入栈操作的时间复杂度,因为只涉及到一个元素的操作,因此非常简单为O(1)。
3.2 出栈
出栈操作就是把元素(数据)从栈中取出,出栈操作又称弹栈,有时也称之为pop操作,均表示出栈操作含义。同样需要注意,根据栈结构的特点,出栈只需要从栈顶取出元素,元素出栈后,原次顶元素会成为新的栈顶元素。
出栈操作的时间复杂度与入栈操作的时间复杂度相同,均是操作栈顶一个元素,因此出栈操作时间复杂度为O(1)。
4. 栈的特点
如上图所示,清晰的展示了栈的入栈操作和出栈操作。可以看到,无论入栈操作,还是出栈操作,都是操作的栈顶元素。
由此,给大家总结栈结构的特点:后进先出,即后进入的元素会先出栈。在计算机术语中,后进先出描述为Last In First Out,简称LIFO;另外也有人表述为先进后出(Frist In Last Out,简称FILO),这两者含义其实是相同的。
5. 栈的应用
在实际的应用实践中,我们可以利用栈结构的特殊性和其特点,解决某些特定的问题,此处给大家介绍常见的几个
5.1 子程序调用
程序在执行过程中,不免会涉及到调用。利用栈结构,可以在跳往子程序前,先将下个指令的地址存到堆栈中,直到子程序执行完后再将地址取出,以便回到原来的程序中。
5.2 浏览器前进和后退
我们使用两个栈X和Y,把首次浏览的页面依次压入栈X,当单击后退按钮时,再依次从栈X中出栈,并将出栈的数据依次放入栈Y。当单击前进按钮时,我们依次从栈Y中取出数据, 放入栈X中。当栈X中没有数据时,说明没有页面可以继续后退浏览了。当栈Y中没有数据,那就说明没有页面可以单击前进按钮浏览了。
5.3 表达式求值
首先大家要知道什么是表达式,以及有哪些表达式,才能进一步学习如何进行表达式求值。根据百科的定义:表达式是由数字、算符、数字分组符号(括号)、自由变量和约束变量等以能求得数值的有意义排列方法所得的组合。
听起来非常的抽象和不好理解,我们可以简单地说:由一个或多个操作数通过操作符组合而成的式子就是表达式。
比如:3+5、a-b、c==d等这些都是表达式,在这三个表达式中,均包含两个操作数和一个操作符。编程中常见和使用的表达式有:算术表达式、逻辑表达式、字符串表达式等。
表达式按照操作数和操作符顺序的不同,又可以分为三种为:中缀表达式、前缀表达式、后缀表达式。
- 中缀表达式:中缀表达式是一个通用的算术或逻辑公式表示方法,我们从小学就接触的算术表达式就是中缀表达式的写法。比如a + b 就默认是中缀表达式。中缀表达式对大家来说很熟悉,但是对计算机来说比较难计算。因为要比较运算符的优先级,所以一般将中缀表达式转化为后缀表达式再进行表达式的运算。
- 前缀表达式:前缀表达式是一种没有括号的算术表达式,与中缀表达式不同的是,其将运算符写在前面,操作数写在后面。为纪念其发明者波兰数学家卢卡西维茨(Jan Lukasiewicz),前缀表达式也称为“波兰表达式”。例如,- 1 + 2 3,它等价于1-(2+3)。
- 后缀表达式:后缀表达式将运算符写在操作数之后。也叫做逆波兰表达式(Reverse Polish notation,RPN,或逆波兰记法)。
在本文中,我们以后缀表达式求值为例,向大家介绍如何利用栈结构计算表达式的值。
首先,我们需要学习后缀表达式运算求值的规则,其运算思路是:从左至右扫描后缀表达式,遇到数字时,将数字压入栈,遇到运算符时,弹出栈顶的两个数,用运算符对它们做出相应的计算,并将结果入栈。重复上述过程,直到表达式的最右端。最后运算得出的值即为表达式的计算结果。
文字描述太过抽象,我们通过具体例子进行说明。例如:求后缀表达式3 4 + 5 * 6 -的值,步骤如下:
(1). 从左向右扫描表达式,首先遇到数字,将数字3和数字4压栈。(此时栈中有2个元素为:3、4)
(2). 继续向右扫描,遇到+运算符。弹出4和3(4为栈顶元素,3为次顶元素),计算4+3=7,将结果7压入栈中。(此时,栈中只有1个元素:7)
(3). 向右继续扫描,遇到数字5,将数字5压入栈中。(此时,栈中包含2个元素:7、5)
(4). 向右扫描,遇到号运算符,弹出栈顶元素5和次栈顶元素7,并计算75=35,将结果35压入栈中。(此时,栈中只有1个元素:35)
(5). 向右扫描,遇到数字6,将数字6压入栈中。(此时,栈中包含2个元素:35,6)
(6). 向右扫描,遇到-运算符,弹出栈顶元素6和次栈顶元素35,并计算35-6=29,将数字29压入栈中。(此时,栈中只有1个元素:29)
(7). 整个表达式扫描结束,取出栈中的元素29,就是最后表达式的结果。
二. 队列
1. 队列的概念
队列 (Queue)也是一种操作受限的线性表,是先进先出的线性表。队列的出口端叫作队头(front),队列的入口端叫作队尾(rear)。队列只允许在队尾进行添加操作,在队头进行删除操作。队列的操作方式和栈类似,唯一的区别在于队列只允许新数据在队尾进行添加,如下图所示:
队列是Java中常用的数据结构,队列的存储结构有两种:一种是基于数组实现的;另一种是基于单链表实现的。
用数组实现队列时,为了入队操作的方便,把队尾位置规定为最后入队元素的下一个位置。 用数组实现的队列叫作顺序队列。数组实现的队列在创建的时候就已经确定了数组的长度,所以队列的长度是固定的,但是可以循环使用数组,所以这种队列也称之为循环队列。
用链表实现的队列叫作链式队列。链表实现的队列内部通过指针指向形成一个队列,这种队列是单向的且长度不固定,所以也称之为非循环队列。
2. 队列的特点
如上图所示,所有的元素都是从队尾进入队列,若需要出队,则从另外一端对头取出元素。我们会发现,元素从队列中出队的顺序刚好是元素进入队列的顺序。我们把这种进入和出来的顺序相同的队列的特点,称之为先进先出(First In First Out,简称为FIFO)。
3. 队列的操作
同栈类似,队列也是一种操作受限,队列有入队和出队两种操作。接下来,我们详细介绍:
3.1 入队
入队又称enqueue,入队就是把新元素放入队列中,只允许在队尾的位置放入元素,新元素的下一个位置将会成为新的队尾。添加数据时,首先判断队列的长度是否超出了数组的长度,如果超出则就添加失败(也可以设置成等待,等队列里的数据出队,然后再添加进去)。元素入队完成后,队列长度加一,rear指针也会相应自增一。如下图所示:
3.2 出队
出队又称dequeue,出队就是把元素移出队列,只允许在队头一侧移出元素,出队元素的后一个元素将会成为新的队头。元素出队后,队列的长度减一,front指针自增一。如下图所示:
4. 时间复杂度
无论是顺序队列还是链式队列,入队和出队操作都只涉及1个元素的操作,因此队列操作的时间复杂度都是O(1)。队列的主要应用于资源池、消息队列、命令队列等。
三. 串
1. 概念
我们通常将字符串简称为串,其是由零个或多个字符组成的有限序列。串可以是字母、数字或其他字符。串中的字符数目称为串的长度,零个字符的串称为空串,它的长度为0。
串中任意个连续字符组成的子序列称为该串的子串,包含子串的串称为主串。通常我们把字符在序列中的序号为该字符在串中的位置,子串在主串中的位置则以子串的第一个字符在主串中的位置来表示。当两个串的长度相等,并且各个对应的字符都相等时,称两个串相等。由一个或多个空格组成的串称为空格串。空格穿并非空串,它有长度,它的长度为串中空格符号的个数。
2. 串的特性
由此,我们可以得知串的几个结论:
- 串是由零个或多个字符组成的有限序列;
- 串可以由字母、数字或其他字符组成;
- 串中的字符数目称为串的长度;
- 零个字符的串称为空串,它的长度为0;
- 串中任意个连续的字符组成的子序列,称为该串的子串;
- 由一个或多个空格组成的串称为空格串;
- 空格穿并非空串,它有长度,它的长度为串中空格符号的个数。
以上这些简洁的结论,在面试题中可能会遇到,大家需要注意一下。关于串的其他操作,我们在后面学习算法时,会单独组织一篇内容进行介绍,此处不再赘述。
四. 结语
本篇文章中,向大家介绍了栈、队列和串三种新的线性数据结构。这三种数据结构相对数组和链表而言,操作比较简单,也比较容易理解,各位在学习时需要记住这几个不同数据结构特有的特点。在时间复杂度分析这个指标上,栈和队列的操作均为O(1)。
关键词:
-
全球头条:maven构建报错:Unable to load the mojo 'install' (or one of its required compone
项目在执行mavencleaninstall时,报错:Failedtoexecutegoalorg apache
来源: 天天新资讯:线性结构中的栈、队列和串是怎么回事?
当前看点!如何将PCM格式的原始音频采样数据编码为MP3格式或AAC格式的音频文件?
全球头条:maven构建报错:Unable to load the mojo 'install' (or one of its required compone
每日聚焦:“降息”靴子落地!
环球观察:《庆余年2》又新增七位女角色,金晨出演叶灵儿
赛力斯SERES 5出海欧洲市场:德国不限速高速飙到225Km/h
颜值超高碾压一众国产!长安启源A07路试:上市就打比亚迪汉
宝马5系首获半自动驾驶认证:变道只需看眼后视镜|世界短讯
100元记3分!杭州对“加塞”司机开罚 网友:请全国推广 消息
广东荔枝价格跌至5年来最低:仅需3、4元一斤
街拍,游走在法律和道德边缘
CSS3有哪些新特性_全球最资讯
全球即时看!数据库三大范式(考试必备)
世界要闻:使用 JMX-Exporter 监控 Kafka 和 Zookeeper
A Practical Methodology, HSM, Handler,Service,Model, for Golang Backend Developm
【环球聚看点】直播源码搭建技术弹幕消息功能的实现
世界观热点:6月20日 11:03分 迈普医学(301033)股价快速拉升
日系还香吗?新一代本田皓影混动/插混上市:19.99万起要打比亚迪_世界报资讯
16.5亿打造!《封神三部曲》第一部7月20上映:预告片发布
全脂/低脂可选:特仑苏纯牛奶2.7元/盒大促(商超6元)
世界快看点丨微软明确不会涉足VR:市场实在太小
红魔8S Pro首发高频版骁龙8 Gen2!170万跑分比骁龙8 Gen3还猛 焦点速讯
【全球新要闻】对在建工程“全面体检”
全球新资讯:关于线性结构中的双向链表如何实现?
NCalc 学习笔记 (六)|天天观热点
也说一说IDEA热部署Web项目最终解决方案,确实大大提高工作效率
每日视点!详解在 Linux 启动时,如何自动执行命令或脚本
最资讯丨失乐园电影迅雷下载 失乐园电影未删减版迅雷下载
债市相对更强,股市估值处相对低位-焦点速递
墓地无人汽车探测到“鬼影”!真相到底是什么?
上海双层敞篷观光巴士将永久退役:已达13年强制报废标准 后继无车
首创双枪充电遥遥领先!比亚迪腾势N7首批量产车下线
高考过后 多所知名大学校长纷纷出镜招生|全球短讯
新买不到一个月特斯拉充电冒烟爆炸 女车主:很失望 产生心理阴影_天天动态
世界观点:菲律宾多方人士反对日本强推核污染水排海:不要污染我们的海洋
springboot~http请求头中如何放中文 当前快报
“泰坦尼克”号残骸观光潜艇氧气仅剩96小时 美加部署飞机搜寻
“全球第一吊”挑战191米最大陆上风力发电机 仅17分钟升至40层楼高
每日短讯:男子长城藏时间胶囊12年多人留纸条 网友直呼奇妙交流:很浪漫
屏摄电影被男子怒斥 影院称屏摄会对胶片有损伤 网友质疑:侮辱智商?-速讯
每日热门:美系开卷国产电动车!别克中大型轿跑E4上市:18.99万起
今日阵雨叨扰,周三周四阳光又将登场,抓紧洗晒! 环球热消息
【读财报】券商资管基金透视:财通、国泰君安资管年内收益领跑 中银证券业绩垫底 视讯
水电大省遭遇“水荒” 四川云南5月水电仍在下降
全球首例!杭州医生用5G帮5000公里外的新疆病人切除肝脏 画面网友惊叹
海口一特斯拉撞飞小车致一死一伤 现场视频被撞车360度旋转、有孩子被甩出-天天时快讯
电瓶车室内充电爆炸 墙都裂了 轮椅老人被吓得拔腿就跑 全球时讯
自救失败!“海航系”公司退市…
读发布!设计与部署稳定的分布式系统(第2版)笔记06_用户_世界观焦点
信息:手机可拆卸电池即将回归:利大于弊 别再被苹果牵着走
环球热资讯!回忆杀!高圆圆晒与贾静雯私照 梦回《倚天屠龙记》周芷若和赵敏
今日看点:早泄能治好吗?
100个物联网项目(基于ESP32)2快速入门
【linux命令】“瑞士军刀”nc的用法简介-天天关注
STL
马云指出淘宝天猫未来三个方向:回归淘宝、回归用户、回归互联网
花了1330万 还有600万只:巴黎向老鼠投降了 要“同居”_全球热点
冷清的618 焦虑的手机厂商:未来只能靠苹果创新了?
跳桥救人小哥引来女网友公开示爱:网友警告切勿炒作 世界热点评
中国男足亚运队1-0胜韩国U24队:孙沁涵抽射建功
美国能单挑全世界吗(美国军力全球第一敢于与世界敌么)
观焦点:登陆百度网盘错误 1550017 百度云同步盘登录失败155010
趋之若鹜的鹜什么意思_趋之若鹜
《王者荣耀》发布S32赛季漂泊之剑预告PV 两款战令皮肤奖励公布
韩国首尔教育厅将对学校供餐用水产品进行全面辐射检测 旨在保证食品安全
微信上线“安静模式” 专为有听力障碍的人创造更好的环境
《庆余年2》公布喜相逢版角色海报 增加一些重要新人物
JUC同步锁原理源码解析五----Phaser 今日热搜
ASP.NET Core MVC 从入门到精通之日志管理_世界热闻
计算几何之两条线段的交点|世界时快讯
看点:博客项目01
“狗狗嫌天热自己坐电梯回家”登上热搜 主人急里忙慌寻找
炒菜用什么油好?
车企卖衣服 不务正业? 焦点信息
微软Win11处理器要求变动:AMD、英特尔一大波新U加入支持
InnoDB 缓冲池
天天资讯:俄罗斯天然气工业银行拟参与无担保人民币债券市场
做小吃前途如何?惠记粉汤羊血加盟开店,开哪儿都火!
天天短讯!特斯拉车祸后复出 演员林志颖首次现身内地商演
专家称年轻人撑不起车市:中老年人才有足够能力拉动市场|视讯
今日精选:予以的拼音(予以)
【财经分析】数据赋能城市升级——2023中国资源型老工业城市转型发展指数研讨会在北京举办
每天喝咖啡的人 20年后都怎么样了?三大好处、三大不要 焦点精选
2024年见 龙芯也要做显卡了:IP设计已完成 还在优化
冷知识!大熊猫近视高达800度:只能看清几米之内物体 看热讯
索尼粉丝迷惑行为:请愿Xbox第一方游戏《星空》成PS5独占
开票!2023年安阳首场演唱会等你来抢!附购票入口
Liunx nginx服务|环球要闻
Manacher算法学习笔记
世界最新:799元价格屠夫!小米电视把国外品牌全打趴了
外来生物美国珍珠鳖被放生太湖:围观者欢呼雀跃|世界简讯
天天热讯:Mate发布Voicebox AI模型:仅需2秒片段即可“学会”语音细节
全球热资讯!首发4899元 外星人新款27英寸游戏显示器上架:180Hz高刷
国产操作系统赶超Win 10 统信UOS更新:换机可批量重装软件
世界头条:因编造、传播与期货交易有关的虚假信息行为 上海点钢电子商务被罚30万元
【环球热闻】Rust语言 - 接口设计的建议之显而易见(Obvious)
天猫品牌评估一般几天_天猫品牌评估_最新消息
北京电动自行车新规今起实施:电池温度达80度需有报警音
世界新消息丨女孩毕业典礼捐10万:含4年奖学金 用于帮助乡村孩子
当前观点:高通、联发科找到共同点了:骁龙8G3、天玑9300 AI性能爆发