大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:
现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔K次就让一个平局。
输入格式:
输入首先在第一行给出正整数K(<=10),即平局间隔的次数。随后每行给出对方的一次出招:“ChuiZi”代表“锤子”、“JianDao”代表“剪刀”、“Bu”代表“布”。“End”代表输入结束,这一行不要作为出招处理。
输出格式:
对每一个输入的出招,按要求输出稳赢或平局的招式。每招占一行。
输入样例:
2
ChuiZi
JianDao
Bu
JianDao
Bu
ChuiZi
ChuiZi
End
输出样例:
Bu
ChuiZi
Bu
ChuiZi
JianDao
ChuiZi
Bu
C语言版本
#include <stdio.h>
#include <string.h>
int main()
{
int K;
scanf("%d", &K);
getchar();
char str[10];
gets(str);
//puts(str);
int n = 1;
// str != End
while (strcmp(str, "End")) {
// 每隔 K 次,要达成平手
if (n % (K+1)) {
if (strcmp(str, "ChuiZi") == 0) {
puts("Bu");
//printf("%s\n", "Bu");
} else if (strcmp(str, "JianDao") == 0) {
puts("ChuiZi");
//printf("%s\n", "ChuiZi");
} else if (strcmp(str, "Bu") == 0) {
puts("JianDao");
//printf("%s\n", "JianDao");
}
} else {
puts(str);
}
gets(str);
n++;
} // while
return 0;
}
Java版本,有一个测试点超时
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int K = scanner.nextInt();
String str = scanner.next();
int n = 1;
// 输入不是 "End" 结束标志,就继续
while (!"End".equals(str)) {
if (n % (K+1) != 0) {
if ("ChuiZi".equals(str)) {
System.out.println("Bu");
} else if ("JianDao".equals(str)) {
System.out.println("ChuiZi");
} else if ("Bu".equals(str)) {
System.out.println("JianDao");
}
} else {
System.out.println(str);
}
str = scanner.next();
n++;
} // while
} // main
}