此题如果要用if else做的话,很繁琐,而且很容易出错
tips:
由于scanf使用%c时会将换行符与空格等输入
因此需要在合适的地方加上getchar()吸收空格
另外输入一定要按样例的格式,有空格的地方一定要输入,不然会出错
程序输入数据后闪退,基本就是这个原因导致的
#include<stdio.h>
int change(char c)
{
if(c=='B')
return 0;
else if(c=='C')
return 1;
else if(c=='J')
return 2;
}
int main()
{
int n;
char mp[4]={'B','C','J'};
scanf("%d",&n);
char a,b;
int i,j;
i=j=0;
int p1[4]={0};
int p2[4]={0};
int q1[4]={0};
int q2[4]={0};
int x,y;
while(n--)
{
getchar();
scanf("%c %c",&a,&b);
//getchar();
x=change(a);
y=change(b);
if((x+1)%3==y)
{
p1[0]++;
p2[2]++;
q1[x]++;
}
else if(x==y)
{
p1[1]++;
p2[1]++;
}
else
{
p1[2]++;
p2[0]++;
q2[y]++;
}
}
printf("%d %d %d\n",p1[0],p1[1],p1[2]);
printf("%d %d %d\n",p2[0],p2[1],p2[2]);
int xx=0;
int yy=0;
for(i=0;i<3;i++)
{
if(q1[i]>q1[xx])
xx=i;
if(q2[i]>q2[yy])
yy=i;
}
printf("%c %c\n",mp[xx],mp[yy]);
return 0;
}
此题要很巧妙地想到一种方法,把字符转化为数字,从小到大,下一个便是前一个的克星,这样就可以判断了,而且把字母存储在一个数组中,这样只要得到最大的数的下标,便可以得到字母了