- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
3.后缀表达式(Postfix Notation) 后缀表达式规定把运算符放在两个运算对象(操作数)的后面。在后缀表达式中,不存在运算符的优先级问题,也不存在任何括号,计算的顺序完全按照运算符出现的先后次次序进行。 4.中缀表达式转换为后缀表达式 其转换方法采用运算符优先算法。转换过程需要两个栈:一个运算符号栈和一个后缀表达式输出符号栈。 * Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose Pty Ltd. (1)读入操作数,直接送输出符号栈。 (2)读入运算符,压入运算符号栈。 (a)?若后进的运算符优先级高于先进的,则继续进栈; (b)?若后进的运算符优先级不高于先进的,则将运算符号栈内高于或等于后进运算符级别的运算符依次弹出后进栈。 (3)括号处理: (a)?遇到开括号“(”,进运算符号栈; (b)遇到闭括号“)”,则把最靠近的开括号“(”,以及其后进栈的运算符依次弹出到符号栈,而括号不压入符号栈。 (4)遇到结束符“#”,则把运算符号栈内的所有运算符号依次弹出,并压入输出符号栈。 (5)若输入为+、–单目运算符,改为0与运算对象在前,运算符在后。 例如:–A,转换为:0A–。 * Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose Pty Ltd. 【例3-2】 A / B ^ C + D * E – A * C 输入符号 A / B ^ C + D * E - A * C # 运算符栈 / / /, ^ /, ^ + + +,* +,* - - -,* -,* 输出结果 A A A,B A,B A,B,C A,B,C, ^,/ A,B,C, ^,/,D A,B,C, ^,/,D A,B,C, ^,/,D,E A,B,C, ^,/,D,E,*,+ A,B,C, ^,/,D,E,*,+,A A,B,C, ^,/,D,E,*,+,A A,B,C, ^,/,D,E,*,+,A,C A,B,C, ^,/,D,E,*,+,A,C,*, - 操作说明 输出A / 进栈 输出B ^优先级高于/,继续进栈 输出C ^,/依次弹出 输出D *优先级高于+,继续进栈 输出E *,+ 依次弹出,- 进栈 输出A *优先级高于 -,继续进栈 输出C 遇到结束符#,依次弹出*,- 动画演示 * Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose Pty Ltd. 【例3-3】3 + 4 /(25–(6 + 15))* 8 输入符号 3 + 4 / ( 25 - ( 6 + 15 ) ) * 8 # 运算符栈 + + +,/ +,/,( +,/,( +,/,(,- +,/,(,-,( +,/,(,-,( +,/,(,-,(,+ +,/,(,-,(,+ +,/,(,- +,/ +,* +.* 输出结果 3 3 3,4 3,4 3,4 3,4,25 3,4,25 3,4,25 3,4,25,6 3,4,25,6 3,4,25,6,15 3,4,25,6,15,+ 3,4,25,6,15,+,- 3,4,25,6,15,+,-,/ 3,4,25,6,15,+,-,/,8 3,4,25,6,15,+,-,/,8,*,+ 操作说明 输出3 +进栈 输出4 / 继续进栈 (进栈 输出25 - 进栈 (再进栈 输出6 +进栈 输出15 遇),依次弹出第2个(后的符号 遇),依次弹出第1个(后的符号 弹出/,但*高于+,继续进栈 输出8 遇到结束符#,依次弹出*,+ * Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile 5.2.0.0. Copyright 2004-2011 Aspose Pty Ltd. 得到后缀表达式为:3 4 25 6 15 + – / 8 * + 5.后缀表达式求值 后缀表达式求值的运算要用到一个数栈stack和一个存放后缀表达式的字符型数组exp。其实现过程就是从头至尾扫描数组中的后缀表达式: (1)当遇到运算对象时,就把它插入到数栈stack中; (2)当遇到运算符时,就执
文档评论(0)