第3章 栈和队列1-栈.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第3章 栈和队列-栈 3.1 栈(stack) 一、 栈的定义:限定仅在表尾进行插入或删除操作的线性表,表尾—栈顶,表头—栈底,不含元素的空表称空栈 特点:先进后出(FILO)或后进先出(LIFO) 问题 栈的应用:数制转换 如十进制数N转换成d进制数C: N=cndn + cn-1dn-1 +…+ c1d1+ c0 C=(cn cn-1 … c0) 例如: (14)10= 1*23 + 1*22 + 1*21 + 0 =(1110)2 (1348)10=2*83 + 5*82 + 0*81 + 4 =(2504)8 栈的应用:表达式计算 例如:3*(7 – 2 ) (1)要正确求值,首先了解算术四则运算的规则: a. 从左算到右 b. 先乘除,后加减 c. 先括号内,后括号外 由此,此表达式的计算顺序为: 3*(7 – 2 )= 3 * 5 = 15 (2)根据上述三条运算规则,在运算的每一步中,对任意相继出现的运算符?1和?2 ,都要比较优先权关系。 栈的顺序实现 顺序栈的类型定义如下: # define StackSize 100 typedef struct { ElemType data[StackSize]; int top; }SqStack; top指向栈顶的上一个元素。 top==0表示空栈。 top== StackSize-1表示栈满。 当栈满时再做进栈运算必定产生空间溢出,简称“上溢”;当栈空时再做退栈运算也将产生溢出,简称“下溢”。 上溢是一种出错状态,应该设法避免之;下溢一般是正常现象,常常用来作为程序控制转移的条件。 顺序栈示例代码 顺序栈的共享单元 栈的链式实现 typedef struct Node{ ElemType elem; struct Node *next; }SNode; 链栈示例代码 作业 1、对于一个栈,给出输入项A、B、C,如果输入项序列由ABC组成,试给出所有可能的输出序列。 2、如果一个栈的输入序列为123456,能否得到435612和135426的出栈序列? 3、设依次进入一个栈的元素序列为c,a,b,d,则可得到出栈的元素序列是: A)a,b,c,d B)c,d,a,b C)b,c,d,a D)a,c,d,b * * 主讲教师 艾彦迪 数据结构讲义 an a1 a2 ……... 栈底 栈顶 ... 出栈 进栈 栈s=(a1,a2,……,an) 栈的基本操作 1.初始化栈:INISTACK(S) 将栈S置为一个空栈(不含任何元素)。 2.进栈:PUSH(S,X) 将元素X插入到栈S中,也称为 “入栈”、 “插入”、 “压入”。 3.出栈: POP(S) 删除栈S中的栈顶元素,也称为”退栈”、 “删除”、 “弹出”。 4.取栈顶元素: GETTOP(S,e) 取栈S中栈顶元素。 5.判栈空: StackEmpty(S) 判断栈S是否为空,若为空,返回值为true,否则返回值为false。 栈的操作演示 一个栈的输入序列是12345,若在入栈的过程中允许出栈,则栈的输出序列43512可能实现吗?12345的输出呢? 43512不可能实现,主要是其中的12顺序不能实现; 12345的输出可以实现,只需压入一个立即弹出一个即可。 (1348)10=2*83 + 5*82 + 0*81 + 4 =(2504)8 n n div 8 n mod 8 1348 168 4 168 21 0 21 2 5 2 0 2 最后得到的“2”最先输出:2504 顺序栈的操作演示flash 顺序栈的共享单元操作演示flash 可附加一个头节点。 插入和删除仅在头节点处进行。 没有栈满的限制。 可以看到,主函数和顺序栈时的ch3_sstack.c一模一样。即逻辑结构完全相同,存储结构不同而已。

文档评论(0)

飞扬的岁月 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档