题目链接
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5269
题目很简单,直接把所有情况列出来。
我的AC代码
#include<stdio.h>
int main()
{
int t;
int a,b,c;
char c1,c2;
int s;
scanf("%d",&t);
getchar();
while(t--)
{
scanf("%d",&a);
getchar();
scanf("%c",&c1);
scanf("%d",&b);
getchar();
scanf("%c",&c2);
scanf("%d",&c);
getchar();
if(c1==‘*‘)
{
if(c2==‘*‘)
s=a*b*c;
else if(c2==‘/‘)
s=a*b/c;
else if(c2==‘%‘)
s=a*b%c;
else if(c2==‘+‘)
s=a*b+c;
else
s=a*b-c;
}
else if(c1==‘/‘)
{
if(c2==‘*‘)
s=a/b*c;
else if(c2==‘/‘)
s=a/b/c;
else if(c2==‘%‘)
s=a/b%c;
else if(c2==‘+‘)
s=a/b+c;
else
s=a/b-c;
}
else if(c1==‘%‘)
{
if(c2==‘*‘)
s=a%b*c;
else if(c2==‘/‘)
s=a%b/c;
else if(c2==‘%‘)
s=a%b%c;
else if(c2==‘+‘)
s=a%b+c;
else
s=a%b-c;
}
else if(c1==‘+‘)
{
if(c2==‘*‘)
s=a+b*c;
else if(c2==‘/‘)
s=a+b/c;
else if(c2==‘%‘)
s=a+b%c;
else if(c2==‘+‘)
s=a+b+c;
else
s=a+b-c;
}
else
{
if(c2==‘*‘)
s=a-b*c;
else if(c2==‘/‘)
s=a-b/c;
else if(c2==‘%‘)
s=a-b%c;
else if(c2==‘+‘)
s=a-b+c;
else
s=a-b-c;
}
printf("%d\n",s);
}
return 0;
}
也可以利用栈的知识。
原文:http://www.cnblogs.com/liudehao/p/3986058.html