题目

  尼姆游戏,这是一个著名的游戏,有很多变种玩法。两个玩家轮流从一堆物品中拿走一部分。在每一步中,玩家可以自由选择拿走多少物品,但是必须拿走一部并且最多只能拿走一半物品,然后轮到下一个玩家。拿走最后一个物品的玩家输掉游戏。先手随机。(2021-12-08 :44)我已优化代码,当时app更新,不支持修正已发博文,另发一篇《尼姆游戏修正优化版》。

代码运行效果


回首页


python代码

#/sur/bin/nve python
# coding: utf-8
import os #用os.system(r'clear')清屏
import random #用random.randint()随机取数def clear():'''#Linux清屏'''clear = os.system(r'clear')def optimal(n):'''机器最优拿法'''if n in (1, 2, 3, 4):return 1take = int(n/2)m = 1for i in range(take):if m>take:breakm *= 2take = n-m+1if take>int(n/2):take = random.randint(1, int(n/2))return takedef common(n):'''机器一般拿法'''while True:if n==1:return 1return random.randint(1, int(n/2))def effect(first, take, n):'''结果输出'''cl()print('\n'*6)flag_s = ('简单', '困难')[flag-1]print('%s\n'%('【%s】'%flag_s).rjust(20))print('﹊'*21)print(' '*4, end='')print('%s已取走%s。物品堆物品还剩%s。'%(first, take, n))print('﹊'*21)def show_error():'''报错信息打印'''print('\n\n%s'%error)print('输入错误!请重试。'.rjust(20))print('﹊'*21)input('任意键继续……'.rjust(20))#Main Codes
cl = clear
s = '''尼姆游戏,这是一个著名的游戏,有很多变种玩法。两个玩家轮流从一堆物品中拿走一部分。在每一步中,玩家可以自由选择拿走多少物品,但是必须拿走一个并且最多只能拿走一半物品,然后轮到下一个玩家。拿走最后一个物品的玩家输掉游戏。先手随机。
'''
#规则打印
cl()
print('\n\n%s'%'“尼姆”游戏规则'.rjust(20))
print()
print('﹊'*21)
print(s)
print('﹊'*21)
input('任意键继续……'.rjust(20))
#难度选择
while True:cl()print('\n'*6)print('\n%s'%'【难度选择】'.rjust(20))print()print('﹊'*21)print('1. 简单  2. 困难'.rjust(24))print('﹊'*21)try:flag = int(input('请选择:'.rjust(12)))if flag not in (1, 2):error()continuebreakexcept Exception as error:show_error()#开始游戏
p = '小可爱'
cl()
print('\n'*6)
while True:try:c = input('给对手命名:'.rjust(12))breakexcept Exception as error:error()continue
if flag==2:n = random.randint(1, 500)
else:n = random.randint(1, 100)
cl()
print('\n'*6)
print('﹊'*21)
print('%s\n'%'【本局游戏物品堆】'.rjust(21))
print(('%s:%3d'%('物品总数', n)).rjust(22))
print('﹊'*21)
input('任意键继续……'.rjust(20))
#随机先手选择
first = random.choice((c, p))
while n>0:#机器取if flag==2 and first==c:take = optimal(n)n = n-takeif flag==1 and first==c:take = common(n)n = n-takeif first==c:effect(first, take, n)if n==0:breakfirst = p #转换玩家先手#玩家取if first==p:while True:try:take = int(input('\n%s'%'您取物:'.rjust(12)))if take==1 and (n in (1, 2, 3)):breakif take>int(n/2) or take<1:error()continue breakexcept Exception as error:show_error()n = n-takeif first==p:effect('您', take, n)input('任意键继续……'.rjust(20))if n==0:breakfirst = c #转换机器先手#结果输出
if first==p:first = '您'
cl()
print('\n'*6)
print('﹊'*21)
print(('%s输了!'%first).rjust(20))
print('﹊'*21)
此篇博文发文时没有完善代码,有些错漏。修正后正值app更新到最新版本,不可以修改已发博文了,才另发一篇“练习:尼姆游戏(优化版)”。今天app再次更新,又能修正已发博文,在此加上后文链接。(2021-12-05)

回首页


上一篇: 练习:任意多行字条串拆分数值求和&冒泡排序&两数的最大公约数和最大公倍数
下一篇: 尼姆游戏(修正优化版)


回首页


精品文章:

  • 通过内置对象理解python
  • Python 完全自学手册
  • 海象运算符
  • Python中的 `!=`与`is not`不同
  • 学习编程的正确方法

来源:老齐教室


练习:尼姆游戏(聪明版/傻瓜式•人机对战)相关推荐

  1. Python代码实现尼姆游戏聪明模式

    Python代码实现尼姆游戏聪明模式 代码问题描述: 尼姆游戏是个著名的游戏,有很多变种玩法.两个玩家轮流从一堆物品中拿走一部分.在每一步中,玩家可以自由选择拿走多少物品,但是必须至少拿走一个并且最多 ...

  2. python编程实验,模拟聪明版的尼姆游戏设计原理

    实验原理与内容: 本实验完成一个模拟聪明版的尼姆游戏功能: 尼姆游戏是个著名的游戏,有很多变种玩法.两个玩家轮流从一堆物品中拿走一部分,在每一步中,玩家可以自由选择拿走多少物品,但是必须至少拿走一个并 ...

  3. 尼姆游戏(聪明版)python

    尼姆游戏是个著名的游戏,有很多变种玩法.两个玩家轮流从一堆物品中拿走一部分.在每一步中,玩家可以自由选择拿走多少物品,但是必须至少拿走一个并且最多只能拿走一半物品,然后轮到下一个玩家.拿走最后一个物品 ...

  4. 使用Python编写一个聪明的尼姆游戏

    关于尼姆游戏的介绍请参考上一篇文章:一个傻傻的尼姆游戏及其Python实现,本文使用Python实现一个聪明的尼姆游戏. 在聪明模式中,计算机每次拿走足够多的物品使得堆的大小是2的幂次方减1--也就是 ...

  5. Python聪明的尼姆游戏(人机对战)

    实验目的: (1)理解尼姆游戏规则. (2)了解多个函数定义与调用. (3)理解并熟练运用 while 循环. (4)理解带 else 子句的循环结构执行流程. (5)理解循环语句中的 break 语 ...

  6. 实验三 聪明的尼姆游戏 (educoder)

    实验三 聪明的尼姆游戏(人机对战) 实验目的: (1)理解尼姆游戏规则 (2)了解并熟练使用while循环 (3)理解带else子句的循环结构执行流程 (4)理解循环语句的break语句的作用 (5) ...

  7. python尼姆游戏_使用Python编写一个聪明的尼姆游戏

    关于尼姆游戏的介绍请参考上一篇文章:一个傻傻的尼姆游戏及其Python实现,本文使用Python实现一个聪明的尼姆游戏. 在聪明模式中,计算机每次拿走足够多的物品使得堆的大小是2的幂次方减1--也就是 ...

  8. python尼姆游戏_python实现聪明的尼姆游戏(人机对战)

    尼姆游戏是个著名的游戏,有很多变种玩法.两个玩家轮流从一堆物品中拿走一部分:在每一步中,玩家可以自由选择拿走多少物品,但是必须至少拿走一个并且最多只能拿走一半物品,然后轮到下一个玩家.拿走最后一个物品 ...

  9. (新手小白必学!)用Python设计和实现聪明的尼姆游戏(人机对战)!!!!

    题目: 尼姆游戏是个著名的游戏,有很多变种玩法.两个玩家轮流从一堆物品中拿走一部分.在每一步中,玩家可以自由选择拿走多少物品,但是必须至少拿走一个并且最多只能拿走一半物品,然后轮到下一个玩家.拿走最后 ...

最新文章

  1. [Web 开发] 定制IE下载对话框的按钮(打开/保存)
  2. layui table 字体大小_layui table设置某一行的字体颜色方法
  3. 宜昌市计算机一级考试真题,2018年上半年湖北省宜昌市计算机等级考试考务通知...
  4. javaweb k8s_阿里云部署K8Sweb项目
  5. 浅谈android hook技术
  6. win11 通过winget安装/卸载v2raya的命令整理
  7. 【数据结构与算法】之有关“跳跃游戏”的求解思路与示例算法
  8. centos下安装pip时失败:
  9. mysql 多键sequence_MySQL增多Sequence管理功能
  10. 推荐系统实战第一部分 协同过滤
  11. 《剑指offer》面试题19——二叉树的镜像(C++)
  12. 命名实体识别研究综述
  13. 解决织梦CMS友情链接的字数个数限制
  14. flash mx拖拽实例_Flash MX 2004 Professional的照片闪光器效果面板
  15. FusionSphere 物理CPU与VCPU的关系梳理总结
  16. 公钥加密数字签名证书的原理总结
  17. 文件分割与合并(Java)
  18. actived生命周期_vue组件的生命周期和执行过程
  19. dubbo之Serialization
  20. 用人话说说文明和文化

热门文章

  1. baidu卫兵新版力推三级加快器 电脑一键提速50%
  2. SAP商超订单统一管理系统
  3. 微机—— 计算机中的数据表示
  4. Unity Shader 实现透明护盾效果
  5. 2020年中山大学CS夏令营
  6. NSLayoutConstraint动态修改multiplier或constant
  7. new relic_Datadog,SignalFX,New Relic,Wavefront –您应该选择哪个仪表板?
  8. flink实战--核心概念解析和应用
  9. 双系统linux哪种好,双系统安装实战,这个Linux系统超级简单
  10. 中国石油大学(北京)-《思想道德修养与法律基础#》第一阶段在线作业