- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构与算法问题析及源代码之表达式求值
表达式求值
1 题目
以字符序列输入一包括加、减、乘、除的正确的四则运算算式(可以包含括号,不包含变量和函数调用),编写程序,利用栈等将中缀表达式转换为后缀表达式并计算该表达式的值。、
2 目的
输入任意合法含括号的四则运算结果,熟悉栈的相关操作与应用。
3 设计思想
用两个堆栈分别存储表达式的数据和运算符,用一个变量来表示运算符的优先级,四则运算时,若后读入的运算符优先级高于前一个运算符,那么就在该运算下计算后两个数据的值,如此直至运算符堆栈为空。用一个变量标记括号,遇到括号则标记加1,每出栈一对括号则标记减1,结合该标号判断运算符的出栈时机。
5 程序流程图
6 源程序
#include stack.h
int is_Operator(char Operator) //判断是不是操作符
{
switch(Operator)
{
case +:
case -:
case *:
case /:
case (:
case ):
return 1;
default: return 0;
}
}
int priority(char Operator) //判断符号优先级
{
switch(Operator)
{
case + :
case - : return 1;
case * :
case / : return 2;
case ( :
case ) : return 3;
default : return 0;
}
}
int two_result(int Operator,int operand1,int operand2) //求出堆栈中两个数的值
{switch(Operator)
{
case +:
return (operand2+operand1);
case -:
return (operand2-operand1);
case *:
return (operand2*operand1);
case /:
return (operand2/operand1);
}
}
int calculate(char *expression){
LinkStack Operator=InitStack(Operator);
LinkStack operand=InitStack(operand);
int position=0;
int op=0;
int operand1=0;
int operand2=0;
int evaluate=0;
bool sign=0;//标记左括号
while(expression[position]!=\0expression[position]!=\n)
{if(!is_Operator(expression[position]))
{
Push(operand,int(expression[position])-48);
position++;
}
else
if(StackEmpty(Operator))
{Push(Operator,int(expression[position]));
position++;
}
else
if(priority(expression[position])prior
您可能关注的文档
- 成都市精神卫生中心建工程基坑降水、支护及施工组织方案.doc
- 成都市级六校联考高数学试题及答案.doc
- 成都市金牛区公开招事业单位工作人员招聘岗位和条件一览表.doc
- 成都市都江堰事业单考试录用公告.doc
- 成都市都江堰事业单考试辅导课程.doc
- 成都市高新区八级下期末考试题及答案 2.doc
- 成都石化工业学校-度(下)下期学生会工作总结.doc
- 成都铁路局200~50kmh客运专线机务运用安全管理办法(试行).doc
- 成都高新区大学生创天使基金商业计划书(转).doc
- 成都市高新区八级下期末考试题及答案.doc
- 数控工控电气自动化程你必须了解的数控系统中软件的测试与诊断方法 国家可编程序PLC设计师考试培训.doc
- 数控专业教学法师资训项目实施方案.doc
- 数据结构课程设计题(最终版)-.doc
- 数控设备应用技术与护专业毕业论文(设计)——加工中心编程与方法.doc
- 数理统计课程论文--重庆市用水量影响因素分析.doc
- 数控机床课程设计--Y数控工作台设计(完整图纸).doc
- 整理过144月施工业三类人员安全生产考核模拟题.doc
- 整理---关于ADL上网共享设置的说明---带图片.doc
- 文件:讨论文件之二关于加强专业学位研究生案例教学的意见(修改稿).doc
- 文字秘书应具备的基知识-机关公文写作知识讲座.doc
最近下载
- 人美版(北京)美术五年级上册20.京剧脸谱(共36张PPT).pptx VIP
- CS345(一) 给水承插铸铁管道支墩.pdf VIP
- WERKAI WKR5000 SERIES Manual说明书用户手册.pdf
- 质量、安全、环保体系管理制度.docx VIP
- 一种镍基合金其冶炼方法、合金盘管及其制备方法.pdf VIP
- 一种镍基高温合金的高纯净冶炼方法.PDF VIP
- 一种高Al低密度镍铁基高温合金铸锭双联冶炼方法.pdf VIP
- 一种高强高弹高塑性镍基高温合金带材及其制备工艺.pdf VIP
- 一种高强高韧耐蚀铁镍基高温合金及其制备方法.pdf VIP
- 专科医生如何带教全科医生课件.pptx VIP
文档评论(0)