- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
合肥学院
算术表达式求值演示
一、 问题分析和任务定义
实验题目:算术表达式求值:一个算术表达式是由操作数(operand),运算符(operator)和界限符(delimiter)组成的。假设操作数是正整数, 运算符只含加减乘除等四种运算符,界限符有左右括号和表达式起始,结束符“#”,如:#(7+15)*(23-28/4)#。引入表达式起始、结束符是为了方便。编程利用“算符优先法”求算术表达式的值。要求: (1)从键盘读入一个合法的算术表达式,输出正确的结果。(2) 显示输入序列和栈的变化过程。选作内容:操作数类型扩充到实数。
问题分析:在带括号的的算术表达式中,界限符包括左右括号以及表达式起始、结束符“#”。假设运算符只有加、减、乘、除4 种,则对一个简单的算术表达式的运算规则如下:
从左至右运算表达式。
先乘、除,后加、减。
先括号内,后括号外。
要想能够实现这个问题,首先,你要从键盘中输入一个字符并判别该字符是运算符还是运算数。如果是运算数就直接进运算数栈。如果是运算符, 则与运算符栈的栈顶元素进行优先级的比较(可以单独写一个优先级比较函数,将每个运算符与其他运算符之间的优先级一一比较出来,可以设置为“”、“”、“=”),如果比较后为“ ”,则将运算数栈依次出栈两次,将该运算符和刚出栈的两个运算数进行计算(单独写一个函数,将“+”、“-”、 “*”、“/”四种情况一一写出来),然后将计算的结果入运算数栈,将读入的运算符入运算符栈;如果比较后为“”,则将该运算符入运算符栈;如果是“=”,同“”,但要注意如果从运算符栈出栈的元素为“ #”和“(”,则运算数栈无需出栈,并且运算符栈也无需入栈。按照上面的步骤,一一读完所有的字符。这样,运算数栈中最后剩下的元素就是该算术表达式的最终结果。注意:整个算法结束的条件是运算符栈为空。(即表达式的起始、结束符相遇)
任务定义:为统一算法的描述,将运算符和界限符统称为算符。这样, 算符集为+,-,*,/,(,),#}。根据上述 3 条运算规则,两个前后相继出现的算符 a1、a2 间的优先关系可以归纳如下:
(1) 若 a1、a2 同为“*”、“/”或同为“+”、“-”,则运算符 a1 的优先级大于 a2。
(2) “*”、“/”的优先级大于“+”、“-”。
(3) 由于“先括号内,后括号外”,若 a1 为“+”、“-”、“*”、“/”,a2 为“(”;或者,a1 为“(”,而a2 为“+”、“-”、“*”、“/”,则 a1 的优先级小于 a2。
(4) 同理,若 a1 为“+”、“-”、“*”、“/”,a2 为“)”;或
者,a1 为“)”,而 a2 为“+”、“-”、“*”、“/”,则 a1 的优先级小于 a2。
若 a1,a2 同为“(”,则 a1 的优先级小于 a2;若 a1,a2 同为“)”, 则 a1 的优先级大于 a2。
表达式的起始、结束符“#”的优先级小于其他所有合法出现的算符。
(7) 若 a1 为“(”,a2 为“)”或a1,a2 同为“#”,则a1,a2 的优先级相同。
表 1:算符 a1 和 a2 间的关系
a1
a2
+
-
*
/
(
)
#
+
-
*
/
(
=
-
)
-
#
-
=
测试用例:输入的运算表达式为:#9*(18+2)+10#
输出格式:显示每一步操作,并且同时显示操作后的序列和栈的变化过程,最后显示正确的结果。
二、 概要设计和数据结构的选择1、数据结构的选择
因为一个算术表达式就是由运算符和运算数两部分构成的,表达式的求值过程就是对这两部分进行操作,并且由运算符的具体操作来控制运算数。所以为了方便操作,首先可以分别设置一个运算符栈 OPTR 和一个运算数栈 OPND,然后, 依次读入表达式中的每个字符。若是操作数则进运算数栈 OPND,反之,则与栈OPTR 的栈顶算符进行优先级比较,并作如下处理:
1、若栈顶算符的优先级大于读入的算符,则让该算符入算符栈 OPTR;
2、若栈顶算符的优先级高于刚读入的算符,则将栈顶算符出栈,同时,将运算数栈 OPND 出栈两次,得到两个操作数x,y,对x,y 用栈顶算符运算后, 再将运算结果入运算数栈 OPND;
3、若栈顶算符和读入算符的优先级相等,说明左右括号相遇,或者是表达式 的起始、结束符相遇。只需将 OPTR 退栈即可。
运算符栈和运算数栈的定义:
typedef struct //创建运算符栈的类型
{ char data[maxlen]; int top;
}stack1;
typedef struct //创建运算数栈的类型
{ int data[maxlen];
int top;
}stack2;
您可能关注的文档
最近下载
- 烟台大学 积极心理学教案烟台大学 积极心理学教案.doc VIP
- 内镜室护士培训课件.pptx VIP
- TED中英官方演讲稿-PatriciaMedici_2015F[Patricia Medici][你一无所知的一种最酷的动物 _ 我们该如何拯救它].pdf VIP
- 专题十 等边三角形(2)——手拉手与夹半角的构造.pptx VIP
- 课题结题报告.docx VIP
- 生成式AI在初中数学课堂中促进分层教学的实践研究教学研究课题报告.docx
- 2022年新生儿科第二季度核心能力考试 (1).docx VIP
- 已更新:安全生产法律法规清单(2025年6月版).doc
- 专题二 全等基本结构(2)——夹半角的构造与截长补短.pptx VIP
- 档案录入员考试真题及答案.docx VIP
原创力文档


文档评论(0)