文章目录
一、题目
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:
现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔K次就让一个平局。
输入格式:
输入首先在第一行给出正整数K(≤10),即平局间隔的次数。随后每行给出对方的一次出招:ChuiZi代表“锤子”、JianDao代表“剪刀”、Bu代表“布”。End代表输入结束,这一行不要作为出招处理。
输出格式:
对每一个输入的出招,按要求输出稳赢或平局的招式。每招占一行。
输入样例:
2
ChuiZi
JianDao
Bu
JianDao
Bu
ChuiZi
ChuiZi
End
输出样例:
Bu
ChuiZi
Bu
ChuiZi
JianDao
ChuiZi
Bu
二、方法1
1、思路
- 因为无论是 ChuiZi、JianDao、Bu 还是 End,它们的首字母都不同,方便起见,我们可以比较它们的首字母;
- 每 K 次平局一次,每次 count++,判断 count > K 即可,别忘记每次平局以后把 count 置为零。
2、代码
#include<stdio.h>
int main()
{
int K, count = 0;
scanf("%d", &K);
char s1[10] = "ChuiZi", s2[10] = "JianDao", s3[10] = "Bu";
char str[20];
while (scanf("%s", str) != EOF)
{
count++;
if (str[0] == 'C')
{
if (count > K)
{
count = 0;
printf("%s\n", str);
}
else
printf("%s\n", s3);
}
else if (str[0] == 'J')
{
if (count > K)
{
count = 0;
printf("%s\n", str);
}
else
printf("%s\n", s1);
}
else if (str[0] == 'B')
{
if (count > K)
{
count = 0;
printf("%s\n", str);
}
else
printf("%s\n", s2);
}
else if (str[0] == 'E')
break;
}
return 0;
}