B1018

#include<cstdio>
#include<iostream>
#include<cmath>
#include<cstring>
#include<string>
#include<ctime>
using namespace std;

int main()
{
    int N;
    scanf("%d",&N);
    int Jy=0,Jp=0,Js=0;
    int J[3]={0},Y[3]={0}; //B 0 C 1 J 2
    char s1,s2;
    for(int i=1;i<=N;i++){
        getchar();
        scanf("%c %c",&s1,&s2);
        if(s1==s2) Jp++;
        else if(s1=='C'&&s2=='J'){
            Jy++;
            J[1]++;
        }else if(s1=='J'&&s2=='B'){
            Jy++;
            J[2]++;
        }else if(s1=='B'&&s2=='C'){
            Jy++;
            J[0]++;
        }else{
            if(s2=='C') Y[1]++;
            else if(s2=='J') Y[2]++;
            else Y[0]++;
            Js++;
        }
    }
    printf("%d %d %d\n",Jy,Jp,Js);
    printf("%d %d %d\n",Js,Jp,Jy);
    if(J[0]>=J[1] && J[0]>=J[2]) printf("B ");
    else if(J[1]>=J[2]) printf("C ");
    else printf("J ");
    if(Y[0]>=Y[1] && Y[0]>=Y[2]) printf("B");
    else if(Y[1]>=Y[2]) printf("C");
    else printf("J");
    printf("\n");
    return 0;
}
 

按照题目意思进行模拟,不过这道题有两个地方要注意,一个是scanf输入字符中由于回车也可以被吸收的理由,需要用getchar进行吸收,第二个解不唯一按字母序排序,所以需要用>=,不然有一个测试点会错

猜你喜欢

转载自blog.csdn.net/fengwuyaQAQ/article/details/85616584
今日推荐