取火柴游戏

甲、乙两人玩抽取火柴的游戏,一共有21根火柴。两个人轮流取火柴,每人每次最少取1根火柴,最多可以取4根火柴,不可多取,也不能不取,谁取到最后一根火柴谁就输了。甲让乙先取火柴,结果每次都是甲获胜。试编写程序,演示取火柴游戏的过程。

示例1:

输入:

3

4

2

4

输出:

乙拿了3根火柴。

甲拿了2根火柴。

乙拿了4根火柴。

甲拿了1根火柴。

乙拿了2根火柴。

甲拿了3根火柴。

乙拿了4根火柴。

甲拿了1根火柴。

轮到乙抽,只剩下1根火柴。乙输了!

解释:

乙先拿了3根火柴,甲后拿了2根火柴,第一轮结束。乙先拿了4根火柴,甲后拿了1根火柴,第二轮结束。乙先拿了2根火柴,甲后拿了3根火柴,第三轮结束。乙先拿了4根火柴,甲后拿了1根火柴。轮到乙抽,只剩下1根火柴。乙输了!游戏结束。

示例2:

输入:

5

4

3

2

1

输出:

输入错误,请重新输入。

乙拿了4根火柴。

甲拿了1根火柴。

乙拿了3根火柴。

甲拿了2根火柴。

乙拿了2根火柴。

甲拿了3根火柴。

乙拿了1根火柴。

甲拿了4根火柴。

轮到乙抽,只剩下1根火柴。乙输了!

解释:

乙拿了5根火柴,程序报错,请重新输入。乙先拿了4根火柴,甲后拿了1根火柴,第一轮结束。乙先拿了3根火柴,甲后拿了2根火柴,第二轮结束。乙先拿了2根火柴,甲后拿了3根火柴,第三轮结束。乙先拿了1根火柴,甲后拿了4根火柴,剩余1根火柴。轮到乙抽,只剩下1根火柴。乙输了!游戏结束。

python 复制代码
def tackMatch(matchNumber=21):
    id = 0 
    take_number = 0
    while matchNumber >= 1:
        id += 1
        if id % 2 == 1:
            gamer = "乙"
            if matchNumber == 1:
                print(f"轮到{gamer}抽,只剩下1根火柴。{gamer}输了!")
                break
            if matchNumber > 5:
                while True:
                    take_number = eval(input())
                    if take_number >= 5:
                        print("输入错误,请重新输入。")
                    else:
                        break           
            else:
                take_number = 1
            print("{}拿了{}根火柴。".format(gamer,take_number))
        else:
            gamer = "甲"
            take_number = 5 - take_number
            print("{}拿了{}根火柴。".format(gamer,take_number))
        matchNumber -= take_number
tackMatch()
相关推荐
Victory_orsh8 分钟前
“自然搞懂”深度学习系列(基于Pytorch架构)——02小试牛刀
人工智能·python·深度学习·神经网络·机器学习
Bruce-li__12 分钟前
CI/CD流水线全解析:从概念到实践,结合Python项目实战
开发语言·python·ci/cd
2401_841495641 小时前
自然语言处理实战——英法机器翻译
人工智能·pytorch·python·深度学习·自然语言处理·transformer·机器翻译
gAlAxy...1 小时前
面试JAVASE基础(五)——Java 集合体系
java·python·面试·1024程序员节
夏玉林的学习之路1 小时前
Anaconda的常用指令
开发语言·windows·python
张可爱1 小时前
20251026-从网页 Console 到 Python 爬虫:一次 B 站字幕自动抓取的实践与复盘
前端·python
B站计算机毕业设计之家2 小时前
计算机视觉python口罩实时检测识别系统 YOLOv8模型 PyTorch 和PySide6界面 opencv (建议收藏)✅
python·深度学习·opencv·计算机视觉·cnn·1024程序员节
张较瘦_2 小时前
[论文阅读] 从 5MB 到 1.6GB 数据:Java/Scala/Python 在 Spark 中的性能表现全解析
java·python·scala
Xiaoweidumpb2 小时前
Linux Docker docker-compose 部署python脚本
linux·python·docker
郝学胜-神的一滴2 小时前
使用 Python 元类与属性实现惰性加载:Effective Python 第47条
linux·服务器·开发语言·python