L1-044 稳赢 (15分)(C语言)
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:
现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔K次就让一个平局。
输入格式:
输入首先在第一行给出正整数K(≤10),即平局间隔的次数。随后每行给出对方的一次出招:ChuiZi代表“锤子”、JianDao代表“剪刀”、Bu代表“布”。End代表输入结束,这一行不要作为出招处理。
输出格式:
对每一个输入的出招,按要求输出稳赢或平局的招式。每招占一行。
输入样例:
2
ChuiZi
JianDao
Bu
JianDao
Bu
ChuiZi
ChuiZi
End
输出样例:
Bu
ChuiZi
Bu
ChuiZi
JianDao
ChuiZi
Bu
作者
陈越
单位
浙江大学
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
#include<stdio.h>
int main()
{
int n,c=0;
char s1[3]={'B','u'},s2[7]={'C','h','u','i','Z','i'};
char s[15],s3[8]={'J','i','a','n','D','a','o'};
scanf("%d",&n);
while(scanf("%s",s))
{
if(s[0]=='C')//锤子
{
c++;//次数
if(c>n)//如果过了n次那就平局,也输出锤子。
{
printf("%s\n",s);
c=0;
}
else printf("%s\n",s1);//如果没有过n次,输出布。
}
else if(s[0]=='B')//下面和上面一样。
{
c++;
if(c>n)
{
printf("%s\n",s);
c=0;
}
else printf("%s\n",s3);
}
else if(s[0]=='J')
{
c++;
if(c>n)
{
printf("%s\n",s);
c=0;
}
else printf("%s\n",s2);
}
else if(s[0]=='E')break;
}
}