- 1、本文档共24页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
3.2 栈的应用举例3.2.5 表达式求值 算符优先法: 4+2*3-10/5 = 4+6-10/5 = 10-10/5 =10-2 = 8 操作数(operand): 进OPND栈 操作符(operator): 进OPTR栈 界限符(delimiter): * 算符间的优先关系: θ1 θ2 + - * / ( ) # + - * / ( ≒ ) # = Precede: 判定运算符栈的栈顶运算符θ1与读入的运算符θ2之间 的优先关系的函数. Operate: 进行二元运算aθb的函数. * 算术表达式求值过程(算法3.4)OperandType EvaluateExpression() {InitStack(OPTR); Push(OPTR, ‘#’); InitStack(OPND); c = getchar(); While(c!=’#’ || GetTop(OPTR)!=’#’){ If(!In(c,OP)){ Push(OPND,c); c = getchar();} // 不是运算符则进栈 else switch(Precede(GetTop(OPTR),c)){ case ‘’: // 栈顶元素优先权低 Push(OPTR,c); c = getchar(); break; case ‘≒’: // 脱括号并接受下一个字符 Pop(OPTR,x); c = getchar(); break; case ‘’: // 退栈并将运算结果入栈 Pop(OPTR,theta); Pop(OPND,b); Pop(OPND,a); Push(OPND,Operate(a,theta,b)); break; default: printf(“Expression error!”); return(ERROR); } // switch } // while return GetTop(OPND); } // EvaluateExpression * 对算术表达式3*(7-2)求值. 步骤 OPTR栈 OPND栈 输入字符 主要操作 1 # 3 * ( 7 - 2 ) # Push(OPND,’3’) 2 # 3 * ( 7 - 2 ) # Push(OPTR,’*’) 3 # * 3 ( 7 - 2 ) # Push(OPTR,’(’) 4 # * ( 3 7 - 2 ) # Push(OPND,’7’) 5 # * ( 3 7 - 2 ) # Push(OPTR,’-’) 6 # * ( - 3 7 2 ) # Push(OPND,’2’) 7 # * ( - 3 7 2 ) # Operate(‘7’,’-‘,’2’) 8 # * ( 3 5 ) # POP(OPTR) 9 # * 3 5 # Operate(‘3’,’*’,’5’) 10 # 15 # Return(GetTop(OPND)) * 例:汉诺塔问题: 将a柱子上的盘移到 c柱,用 b柱放临时盘 要求:一次只能移动一
您可能关注的文档
- 1.1.1任意角公开课.ppt
- 1.1.1正弦定理2解的个数.ppt
- 1.1.1正弦定理比赛获奖.ppt
- 1~7月份生产部工作报告.ppt
- 1例新生儿大疱性表皮松解症的护理.ppt
- CAD与计算机绘图.ppt
- SYB创业培训第一步将你作为创业者来评价.ppt
- 病理工作流程.ppt
- 常见物质的检验苏教版必修1.ppt
- 程序基本结构.ppt
- 专题5.2 一次函数的图象与性质(一)【十大题型】(举一反三)(浙教版)(原卷版).pdf
- 专题5.2相交线(2)垂线-2021-2022学年七年级数学下册尖子生同步培优题典(解析版)【人教版】.pdf
- 专题5.3 分式方程-重难点题型(举一反三)(北师大版)(解析版).pdf
- 给水工程施工组织设计方案.pdf
- 专题5.2期末全真模拟试卷02(八上人教,培优卷)-2023-2024学年八年级数学上学期复习备考高分秘籍【人教版】(原卷版).pdf
- 高压燃气管道安装工程施工组织设计.pdf
- 高支模施工组织设计.pdf
- 专题5.3 方案选择问题(压轴题专项讲练)(浙教版)(解析版).pdf
- 高支模专门方案(天面层).pdf
- 专题5.3 分式的加减法运算(专项训练)(解析版).pdf
最近下载
- 翼状胬肉的护理查房-PPT.ppt
- 2022年应急管理工作应知应会知识竞赛题库(含答案).pdf
- 全民微信时代增进了VS减弱了人与人之间的交流辩论赛 正方辩词一辩、二辩、三辩、四辩发言稿.docx
- 超星网课尔雅《人人学点营销学》尔雅答案2022章节测试答案.docx
- 2019CSP-J NOIP普及组初赛C++试卷.pdf VIP
- 2024年《城镇燃气管理条例题库》考试题库(含答案).pdf VIP
- 最新浙教版八年级上册劳动技术 项目三 任务二《打蛋器的制作》课件(课件).pptx
- 纪律意识方面存在不足及措施4篇.pdf
- 消防安全教育PPT课件.pptx VIP
- 《新中国成立75周年》全文课件.ppt VIP
文档评论(0)