- 1、本文档共28页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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
您可能关注的文档
最近下载
- 高考英语 听力考点归纳和总结.pdf VIP
- 施工方案交底记录表完整.docx VIP
- 事业单位面试真题(结构化面试)100题(含答案).pdf VIP
- 2025年部编版八年级历史下册第五、六单元总复习课件(23张PPT).pptx VIP
- 水产养殖技艺竞赛题库(94年版).doc VIP
- 上海2024年中考英语词性转换专题训练 .docx
- 新教科版(2020版)科学三年级下册分组实验报告单(原创、全册).docx VIP
- SL∕T 824-2024 水利工程建设项目文件收集与归档规范.docx
- 2022年甘肃省兰州市中考道德与法治试卷.doc
- JC∕T 2669-2022 气凝胶中空玻璃.pdf
文档评论(0)