实验一: 编写一个计算算术表达式的程序
一:程序的设计内容 输入一个表达式; 采用栈的方式将中缀转后缀(操作符入栈); 再由后缀求值。
二:基本要求 编写栈; 使用模板类; 所有数可为个位数; 可以省略括号。
三:分析程序及实验方法 擅于调用模板函数; 多查阅资料,多看典例;
如计算:3*((2+3)-(5-3)^3) 结果为-66
部分功能
1、优先级判断
char Precede(char ch1,char ch2)
{
char ch;
switch(ch1)
{
case '+':
case '-':
{
switch(ch2)
{
case '+':
case '-':
case ')':
case '#':
ch='>';
break;
case '*':
case '/':
case '(':
case '^':
ch='<';break;
}
break;
}
case '*':
case '/':
case '%':
{
if(ch2=='(')
ch='<';
else if(ch2 == '^')
ch = '<';
else
ch='>';
break;
}
case '(':
{
if(ch2==')')
ch='=';
else
ch='<';
break;
}
case ')':
{
ch='>';
break;
}
case '=':
{
if(ch2=='=')
ch='=';
else
ch='<';
break;
}
case '^':
{
if(ch2 == '(')
ch = '<';
else
ch ='>';
break;
}
case 'r':case '#':
{
if(ch2 =='r'||ch2 == '#')
ch = '=';
else
ch='<';
break;
}
}
return(ch);
}
2、结果计算
double calc(double x,char ch,double y)
{
double z;
switch(ch)
{
case '+': z=x+y; break;
case '-': z=x-y; break;
case '*': z=x*y; break;
case '/': z=x/y; break;
case '%': z=x/y; break;
case '^':z=pow(x,y);break;
}
return(z);
}
3、求后缀表达式
double middexpression(char *exp)
{
stack *opnd=new(stack);
stack *optr=new(stack);
char ch = *exp;
double x= 0,y,z;
double result;
optr->push('#');
while(ch != ' ')
{
if(ch >= '0' && ch <= '9')
{
x = ch -48;
opnd->push(x);
ch = *++exp;
if(ch >='0' && ch <= '9')
{
cout<<"不符合要求,运算数必须是0~9之间的数"<gettop(),ch))
{
case '<':
optr->push(ch);
ch =*++exp;
if(ch == ' ')
{
cout<<"表达式错误,操作符不能作结尾!"<':
break;
default:
break;
}
}else if(ch != ' ' && !Operator(ch)&&ch !=' ')
{
cout<<"不符合要求,只能进行:+,-,*,/,^,(,)运算"< 

