PAT——乙级 1018锤子剪刀布

此题如果要用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;
}

此题要很巧妙地想到一种方法,把字符转化为数字,从小到大,下一个便是前一个的克星,这样就可以判断了,而且把字母存储在一个数组中,这样只要得到最大的数的下标,便可以得到字母了

猜你喜欢

转载自blog.csdn.net/qq_42232118/article/details/81414050
今日推荐