鱼C论坛

 找回密码
 立即注册
查看: 2371|回复: 1

[已解决]如果我要计算这个程序的步数,应该怎样修改?

[复制链接]
发表于 2016-11-15 19:14:17 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
这是小甲鱼PYTHON第24课的汉诺塔游戏WG,如果我要把步数统计出来应该怎么修改

def hannoi(n,x,y,z):
    if n == 1:
        print(x,'-->',z)
    else:
        hannoi(n-1,x,z,y)
        print(x,'-->',z)
        hannoi(n-1,y,x,z)
        

n = int(input('请输入盘子数:'))
hannoi(n,'x','y','z')

求助
最佳答案
2016-11-15 19:50:31
  1. def hannoi(n,x,y,z):
  2.     global i
  3.     if n == 1:
  4.         i += 1
  5.         print('step ', i, ': ',  x,'-->',z)
  6.     else:
  7.         hannoi(n-1,x,z,y)
  8.         i += 1
  9.         print('step ', i, ': ',  x,'-->',z)
  10.         hannoi(n-1,y,x,z)
  11.         
  12. i = 0
  13. n = int(input('请输入盘子数:'))
  14. hannoi(n,'x','y','z')
  15. print('总步数:', i)
复制代码

  1. 请输入盘子数:3
  2. step  1 :  x --> z
  3. step  2 :  x --> y
  4. step  3 :  z --> y
  5. step  4 :  x --> z
  6. step  5 :  y --> x
  7. step  6 :  y --> z
  8. step  7 :  x --> z
  9. 总步数: 7
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-11-15 19:50:31 | 显示全部楼层    本楼为最佳答案   
  1. def hannoi(n,x,y,z):
  2.     global i
  3.     if n == 1:
  4.         i += 1
  5.         print('step ', i, ': ',  x,'-->',z)
  6.     else:
  7.         hannoi(n-1,x,z,y)
  8.         i += 1
  9.         print('step ', i, ': ',  x,'-->',z)
  10.         hannoi(n-1,y,x,z)
  11.         
  12. i = 0
  13. n = int(input('请输入盘子数:'))
  14. hannoi(n,'x','y','z')
  15. print('总步数:', i)
复制代码

  1. 请输入盘子数:3
  2. step  1 :  x --> z
  3. step  2 :  x --> y
  4. step  3 :  z --> y
  5. step  4 :  x --> z
  6. step  5 :  y --> x
  7. step  6 :  y --> z
  8. step  7 :  x --> z
  9. 总步数: 7
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-2-23 22:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表