大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:
现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔K次就让一个平局。
输入格式:
输入首先在第一行给出正整数K(≤10),即平局间隔的次数。随后每行给出对方的一次出招:ChuiZi代表“锤子”、JianDao代表“剪刀”、Bu代表“布”。End代表输入结束,这一行不要作为出招处理。
输出格式:
对每一个输入的出招,按要求输出稳赢或平局的招式。每招占一行。
输入样例:
2 ChuiZi JianDao Bu JianDao Bu ChuiZi ChuiZi End
输出样例:
Bu ChuiZi Bu ChuiZi JianDao ChuiZi Bu
代码:
#include<stdio.h>
#define MAX 10000
char a[MAX];
char arr[MAX][MAX];
int main()
{
int i=0,j;
int n;
scanf("%d",&n);
while(scanf("%s",arr[i++]))
{
if(arr[i-1][0]=='E'&&arr[i-1][1]=='n')break;
}
// printf("%d\n",i);
int k;
int kk=0;
int temp=0;
for(k=0;k<i-1;k++)
{
if(temp!=n)
{
if(arr[k][0]=='C'&&arr[k][1]=='h'&&arr[k][2]=='u')
{a[kk++]='b';temp++;}
if(arr[k][0]=='J'&&arr[k][1]=='i'&&arr[k][2]=='a')
{a[kk++]='c';temp++;}
if(arr[k][0]=='B'&&arr[k][1]=='u')
{a[kk++]='j';temp++;}
}
else
{
if(arr[k][0]=='C'&&arr[k][1]=='h'&&arr[k][2]=='u')
{a[kk++]='c';temp=0;}
if(arr[k][0]=='J'&&arr[k][1]=='i'&&arr[k][2]=='a')
{a[kk++]='j';temp=0;}
if(arr[k][0]=='B'&&arr[k][1]=='u')
{a[kk++]='b';temp=0;}
}
}
for(i=0;i<kk;i++)
{
if(a[i]=='c')printf("ChuiZi\n");
if(a[i]=='j')printf("JianDao\n");
if(a[i]=='b')printf("Bu\n");
}
return 0;
}