老式的计算机只能按照固定次序进行运算,华安大学就有这样一台老式计算机,计算模式为A @ B #C,@和#为输入的运算符(可能是+、*、%,须考虑计算优先级),现给出A,B,C的数值以及@和#对应的运算符,请你编写程序,验证老式计算机的运行结果。
输入说明:
第一行是一个整数N(|N|≤10000),表示有N组计算数据需要处理,接下来N行,每行是相应的数据,包括三个整数和两个运算符,分别对应A、@、B、#和C。
输出说明:
对每行输入的数据,输出计算结果。
输入样例:
3
1+2*3
3%2+1
5+7%9
输出样例:
7
2
12
本题属于模拟题,即模拟出所有可能的情况即可
共两个字符 每个字符都可能是 + - * / % 五种情况
所有一共会有 5*5 = 25 种计算可能
输入数据是固定的,格式为 A @ B #C
即 数字 字符 数字 字符 数字 字符
看出规律的话就很简单了
/*1.表达式求值
老式的计算机只能按照固定次序进行运算,华安大学就有这样一台老式计算机,计算模式为A @ B #C,@和#为输入的运算符(可能是+、*、%,须考虑计算优先级),现给出A,B,C的数值以及@和#对应的运算符,请你编写程序,验证老式计算机的运行结果。
输入说明:
第一行是一个整数N(|N|≤10000),表示有N组计算数据需要处理,接下来N行,每行是相应的数据,包括三个整数和两个运算符,分别对应A、@、B、#和C。
输出说明:
对每行输入的数据,输出计算结果。
输入样例:
3
1+2*3
3%2+1
5+7%9
输出样例:
7
2
12 */
/*
本题属于模拟题,即模拟出所有可能的情况即可
共两个字符 每个字符都可能是 + - * / % 五种情况
所有一共会有 5*5 = 25 种计算可能
输入数据是固定的,格式为 A @ B #C
即 数字 字符 数字 字符 数字 字符
看出规律的话就很简单了
*/
#include<iostream>
#include<cmath>
#include<cstring>
#include<cstdio>
using namespace std;
int main()
{
int n;
cin>>n;
int a,b,c;
char x,y;
while(n--){
cin>>a>>x>>b>>y>>c;
int ans = 0;
if(x=='+'){
if(y=='+')
ans = a+b+c;
else if(y=='-')
ans = a+b-c;
else if(y=='*')
ans = a+(b*c);
else if(y=='/')
ans = a+(b/c);
else if(y=='%')
ans = a+(b%c);
}
else if(x=='-'){
if(y=='+')
ans = a-b+c;
else if(y=='-')
ans = a-b-c;
else if(y=='*')
ans = a-(b*c);
else if(y=='/')
ans = a-(b/c);
else if(y=='%')
ans = a-(b%c);
}
else if(x=='*'){
if(y=='+')
ans = a*b+c;
else if(y=='-')
ans = a*b-c;
else if(y=='*')
ans = a*b*c;
else if(y=='/')
ans = a*b/c;
else if(y=='%')
ans = a*b%c;
}
else if(x=='/'){
if(y=='+')
ans = a/b+c;
else if(y=='-')
ans = a/b-c;
else if(y=='*')
ans = a/b*c;
else if(y=='/')
ans = a/b/c;
else if(y=='%')
ans = a/b%c;
}
else if(x=='%'){
if(y=='+')
ans = a%b+c;
else if(y=='-')
ans = a%b-c;
else if(y=='*')
ans = a%b*c;
else if(y=='/')
ans = a%b/c;
else if(y=='%')
ans = a%b%c;
}
cout<<ans<<endl;
}
return 0;
}