欢迎来到天天文库
浏览记录
ID:34722461
大小:61.68 KB
页数:3页
时间:2019-03-10
《c程序代码-中缀表达式求值》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
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、
14、ch=='');//32是空格符代码}voidError(char*c){cerr<&OpndS,MathOperatoroptr){doubleopnd1=OpndS.Pop();doubleopnd2=OpndS.Pop();switch(optr.op){case'+':OpndS.Push(opnd2+opnd1);break
15、;case'-':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、<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.E20、mpty()&&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,否则输入非法Er21、ror("Operandexpected");while(!optrS.Empty())//清空运算符栈{optr2=optrS.Pop();if(optr2.op=='(')Error("Missingrightparenthesis");Evaluate(opndS,optr2);}cout<<"Thevalueis"<
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.E
20、mpty()&&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,否则输入非法Er
21、ror("Operandexpected");while(!optrS.Empty())//清空运算符栈{optr2=optrS.Pop();if(optr2.op=='(')Error("Missingrightparenthesis");Evaluate(opndS,optr2);}cout<<"Thevalueis"<
此文档下载收益归作者所有