模拟简单运算器的工作。假设计算器只能进行加减乘除运算,运算数和结果都是整数,四种运算符的优先级相同,按从左到右的顺序计算。
输入格式:
输入在一行中给出一个四则运算算式,没有空格,且至少有一个操作数。遇等号”=”说明输入结束。
输出格式:
在一行中输出算式的运算结果,或者如果除法分母为0或有非法运算符,则输出错误信息“ERROR”。
输入样例:
1+2*10-10/2=
输出样例:
10
>_code
#include <iostream>
#include <string>
#include <cstring>
#include <cmath>
#define N 50
using namespace std;
class Calculator{
private:
string exp;
int obj[N];
char opr[N];
int ret;
int count;
public:
Calculator(string e = ""):exp(e){}
int my_itoi(int *opj)
{
int ob = 0,i = 0;
for(i=0;i<N;i++)
{
if(opj[i] == -1)
break;
}
i--;
for(int j=i;j>=0;j--)
{
ob = ob+opj[j]*pow(10,i-j);
}
return ob;
}
void split_exp()
{
int i = 0,j = 0,k = 0,m = 0;
int temp[N];
char c;
for(i;i<exp.size();i++)
{
c = exp.at(i);
if(c >= '0' && c <= '9')
{
temp[j++] = c - '0';
}
else
{
opr[k++] = c;
temp[j++] = -1;
obj[m++] = my_itoi(temp);
memset(temp,0,N);
j=0;
}
}
count = m;
}
bool cal_ret()
{
int i = 0,j = 0;
ret = obj[j++];
while(opr[i] != '=')
{
switch(opr[i])
{
case '+':
ret += obj[j++];
break;
case '-':
ret -= obj[j++];
break;
case '*':
ret *= obj[j++];
break;
case '/':
if(0 == obj[j])
return false;
else
ret /= obj[j++];
break;
default:
return false;
}
i++;
}
return true;
}
void get_ret()
{
if(cal_ret())
cout<<ret<<endl;
else
cout<<"ERROR"<<endl;
}
void show()
{
for(int i=0;i<count;i++)
{
cout<<obj[i]<<" ";
}
cout<<endl;
for(int i=0;i<strlen(opr);i++)
{
cout<<opr[i]<<" ";
}
cout<<endl;
}
};
int main(int argc, char const *argv[])
{
string input_exp;
cin>>input_exp;
Calculator ex(input_exp);
ex.split_exp();
//ex.show();
ex.get_ret();
return 0;
}
本文链接:https://shengto.top/cpp/pat_cpp1.html
转载时须注明出处及本声明