第3章栈和队列A--数据结构课件(吴伟民-严蔚敏编著).ppt

第3章栈和队列A--数据结构课件(吴伟民-严蔚敏编著).ppt

  1. 1、本文档共28页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第3章栈和队列A--数据结构课件(吴伟民-严蔚敏编著)

数据结构课程的内容;上堂课若干问题讨论;讨论:自测卷第七题第2小题;3.1 栈(Stack) ;1. 定义;问:堆栈是什么?它与一般线性表有什么不同?;栈 是仅在表尾进行插入、删除操作的线性表。 表尾(即 an 端)称为栈顶 top ; 表头(即 a1 端)称为栈底base;顺序栈示意图; a1;入栈操作——例如用堆栈存放(A,B,C,D) (注意要遵循“后进先出” 原则); 出栈操作——例如从栈中取出‘B’ (注意要遵循“后进先出” 原则);例1:一个栈的输入序列是12345,若在入栈的过程中允许出栈,则栈的输出序列43512可能实现吗?12345的输出呢?;例3(严题集3.1)一个栈的输入序列为123,若在入栈的过程中允许出栈,则可能得到的出栈序列是什么?;例4:计算机系2001年考研题(程序设计基础);补充1: 若入栈动作使地址向高端增长,称为“向上生成”的栈; 若入栈动作使地址向低端增长,称为“向下生成”的栈; 对于向上生成的栈 入栈口诀:堆栈指针top先压后加(v[top++]=x); 出栈口诀:堆栈指针top先减后弹(y=v[--top]) 。;补充3:链栈 链栈示意图; 链栈的入栈函数、出栈函数 (以头指针为栈顶,在头指针处插入或删除!);Push (SElemType x) { p=(NODE*)malloc(m); if(!p){上溢} else{ p-data=x; p-link=st; st=p;} };① 链栈不必设头结点,因为栈顶(表头)操作频繁; ②采用链栈存储方式,可使多个栈共享空间;当栈中元素个数变化较大,且存在多个栈的情况下,链栈是栈的首选存储方式。;问:为什么要设计堆栈?它有什么独特用途?; 数制转换(十转N) ——P48 设计思路:用栈暂存低位值 例2:括号匹配的检验————P49 设计思路:用栈暂存左括号 例3 :表达式求值 —-————P52 设计思路:用栈暂存运算符 例4:汉诺仪(Hanoi)塔-——P55 设计思路:用栈实现递归调用;例3 表达式求值 ( 这是栈应用的典型例子 ) 这里,表达式求值的算法是 “算符优先法”。;(2)根据上述三条运算规则,在运算的每一步中,对任意相继出现的算符?1和?2 ,都要比较优先权关系。 算符优先法所??据的算符间的优先关系见教材P53表3.1 (是提供给计算机用的表!) 由表可看出,右括号 ) 和井号 # 作为?2时级别最低; 由c 规则得出: * ,/, + ,-为?1时的优先权低于‘(’,高于‘)’ 由a规则得出:‘(’=‘)’ 表明括号内运算,已算完。 ‘ # ’=‘ # ’ 表明表达式求值完毕。;(3)算法思想: 设定两栈:操作符栈 OPTR ,操作数栈 OPND 栈初始化:设操作数栈 OPND 为空;操作符栈 OPTR 的栈底元素为表达式起始符 ‘#’; 依次读入字符:是操作数则入OPND栈,是操作符则要判断: if 操作符 栈顶元素,则退栈、计算,结果压入OPND栈; 操作符 = 栈顶元素且不为‘#’,脱括号(弹出左括号); 操作符 栈顶元素,压入OPTR栈。;栈的应用(表达式求值);Status EvaluateExpression( OperandType result) { InitStack(OPND); InitStack(OPTR);Push(OPTR ,’#’);c=getchar(); while((c!=‘#’)(GetTop(OPTR)!=‘#’)) { if (!In(c,OP) { Push(OPND,c); c=getchar();} else switch(compare(c,GetTop(OPTR))) {case ‘’ : Push(OPTR , c); c=getchar();break; case ‘=’: Pop(OPTR);c=getchar();break; case ‘’ : temat=Pop(OPTR); b=Pop();a=Pop(); re

文档评论(0)

l215322 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档