L1-044 稳赢(Python实现) 测试点全过

题目

大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:
L1-044 稳赢(Python实现) 测试点全过_第1张图片
现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔K次就让一个平局。

输入格式
输入首先在第一行给出正整数 K ( ≤ 10 ) K(≤10) K10,即平局间隔的次数。随后每行给出对方的一次出招:ChuiZi代表“锤子”、JianDao代表“剪刀”、Bu代表“布”。End代表输入结束,这一行不要作为出招处理。

输出格式:
对每一个输入的出招,按要求输出稳赢或平局的招式。每招占一行。

输入样例:

2
ChuiZi
JianDao
Bu
JianDao
Bu
ChuiZi
ChuiZi
End

输出样例:

Bu
ChuiZi
Bu
ChuiZi
JianDao
ChuiZi
Bu

题解

K = int(input())  # 读取平局间隔的次数

draw_counter = 0  # 平局计数器初始化为0

while True:
    opponent_gesture = input()  # 读取对方出招

    if opponent_gesture == "End":
        break  # 如果对方出招为"End",退出循环

    if draw_counter == K:
        # 达到平局计数器要求的次数,输出平局的手势
        if opponent_gesture == "ChuiZi":
            print("ChuiZi")
        elif opponent_gesture == "JianDao":
            print("JianDao")
        elif opponent_gesture == "Bu":
            print("Bu")
        draw_counter = 0  # 重置平局计数器
    else:
        # 平局计数器未达到要求,根据对方出招选择稳赢的手势
        if opponent_gesture == "ChuiZi":
            print("Bu")
        elif opponent_gesture == "JianDao":
            print("ChuiZi")
        elif opponent_gesture == "Bu":
            print("JianDao")
        draw_counter += 1  # 平局计数器加1

你可能感兴趣的:(python,算法,数据结构)