PAT 1018锤子剪刀布

1018 锤子剪刀布 (20)(20 分)

大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:
现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。
输入格式:
输入第1行给出正整数N(<= 10 5 ),即双方交锋的次数。随后N行,每行给出一次交锋的信息,即甲、乙双方同时给出的的手势。C代表“锤子”、J代表“剪刀”、B代表“布”,第1个字母代表甲方,第2个代表乙方,中间有1个空格。
输出格式:
输出第1、2行分别给出甲、乙的胜、平、负次数,数字间以1个空格分隔。第3行给出两个字母,分别代表甲、乙获胜次数最多的手势,中间有1个空格。如果解不唯一,则输出按字母序最小的解。
输入样例:

10
C J
J B
C B
B B
B C
C C
C B
J B
B C
J J

输出样例:

5 3 2
2 3 5
B B




解析

这题就是把结果枚举出来就行了。


scanf("%c %c",&A,&B);

没想到这里有坑,如果这样写的话,字符串也会接收输入\n,会导致错误,要写出

 scanf(" %c %c",&A,&B);

在c reference里也有写:
这里写图片描述

#include<stdio.h>
int max(int d1,int d2,int d3){
  if(d1>d2 && d1>d3)
    return d1;
  if(d2>d1 && d2>d3)
    return d2;
  return d3;
}
int main()
{
  int time=0;
  char A;
  char B;
  scanf("%d",&time);

  int win=0;
  int tie=0;
  int lost=0;
  int cc1=0;
  int bb1=0;
  int jj1=0;
  int cc2=0;
  int bb2=0;
  int jj2=0;
  for(int i=0;i<time;i++){
    scanf("\n%c %c",&A,&B);
    if( A=='C' && B=='J'){ 
     cc1++;
     win++;
    }
    else if( A=='B' && B=='C' ){
      bb1++;
      win++;
    }
    else if( A=='J' && B=='B'){
      jj1++;
      win++;
    }

    else if( A=='B' && B=='B' ){
      tie++;
    }
    else if( A=='C' && B=='C' ){
      tie++;
    }

    else if( A=='J' && B=='J' ){
      tie++;
    }

    else if( B=='C' && A=='J' ){
      cc2++;
    }
    else if( B=='B' && A=='C'){
      bb2++;
    }
    else if( B=='J' && A=='B' ){
      jj2++;
    }
  }
  lost = time-win-tie;
  printf("%d %d %d\n",win,tie,lost);
  printf("%d %d %d\n",lost,tie,win);
  int Max1 =max(cc1,bb1,jj1);
  int Max2=max(cc2,bb2,jj2);
  if(bb1==  Max1)
    printf("B");
  else if(cc1== Max1)
    printf("C");
  else
    printf("J");

  if(bb2==  Max2 )
    printf(" B");
  else if(cc2== Max2)
    printf(" C");
  else
    printf(" J");

  return 0;
}

猜你喜欢

转载自blog.csdn.net/weixin_41256413/article/details/81012624
今日推荐