C程序代码-中缀表达式求值.doc

C程序代码-中缀表达式求值.doc

ID:51686767

大小:38.45 KB

页数:3页

时间:2020-03-15

C程序代码-中缀表达式求值.doc_第1页
C程序代码-中缀表达式求值.doc_第2页
C程序代码-中缀表达式求值.doc_第3页
资源描述:

《C程序代码-中缀表达式求值.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、#include#include//包含函数isdigit原型#include"stack.h"//链栈类模板#include"mathoperator.h"//配有运算符类intisoperator(charch)//判断运算符和左括号{return(ch=='+'

2、

3、ch=='-'

4、

5、ch=='*'

6、

7、ch=='/'

8、

9、ch=='(');}intiswhitespace(charch)//判断空格符,格式符和换行符{return(ch==32

10、

11、ch=='t'

12、

13、c

14、h=='');//32是空格符代码}voidError(char*c){cerr<&OpndS,MathOperatoroptr){doubleopnd1=OpndS.Pop();doubleopnd2=OpndS.Pop();switch(optr.op){case'+':OpndS.Push(opnd2+opnd1);break;c

15、ase'-':OpndS.Push(opnd2-opnd1);break;case'*':OpndS.Push(opnd2*opnd1);break;case'/':OpndS.Push(opnd2/opnd1);break;}}intmain(){intrank=0;charch;doublenumber;MathOperatoroptr1,optr2;StackopndS;//操作数栈StackoptrS;//运算符栈cout<<"Enteraninfix:"<

16、ndl;//输入提示:输入一个表达式while(cin.get(ch)&&ch!='=')//如果不是表达式结束符"="{if(isdigit(ch)

17、

18、ch=='.')//读入操作数第一个符号{cin.putback(ch);//若是数字,则把该数字退回输入缓冲区cin>>number;//从输入缓冲区读取一个完整的操作数rank++;if(rank>1)Error("Operatorexpected");opndS.Push(number);}elseif(isoperator(ch))//读入运算符,包括左

19、括号{if(ch!='(')//读入运算符,且非左括号rank--;if(rank<0)Error("Operandexpected");optr1=MathOperator(ch);while(!optrS.Empty()&&optrS.Top()>=optr1){optr2=optrS.Pop();Evaluate(opndS,optr2);}optrS.Push(optr1);}elseif(ch==')')//读入右括号{optr1=MathOperator(ch);while(!optrS.Empty(

20、)&&optrS.Top()>=optr1)//取出子表达式运算符{optr2=optrS.Pop();Evaluate(opndS,optr2);}if(optrS.Empty())//没有遇到左括号Error("Missingleftparenthesis");optrS.Pop();//删除左括号}elseif(!iswhitespace(ch))//读取空格或换行符,继续读取。Error("Invalidinput");}if(rank!=1)//读入结束符,rank必须为1,否则输入非法Error("O

21、perandexpected");while(!optrS.Empty())//清空运算符栈{optr2=optrS.Pop();if(optr2.op=='(')Error("Missingrightparenthesis");Evaluate(opndS,optr2);}cout<<"Thevalueis"<

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。