欢迎来到天天文库
浏览记录
ID:51686767
大小:38.45 KB
页数:3页
时间:2020-03-15
《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("O21、perandexpected");while(!optrS.Empty())//清空运算符栈{optr2=optrS.Pop();if(optr2.op=='(')Error("Missingrightparenthesis");Evaluate(opndS,optr2);}cout<<"Thevalueis"<
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"<
此文档下载收益归作者所有