• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

使用python实现递归版汉诺塔示例(汉诺塔递归算法)

python 搞代码 4年前 (2022-01-07) 44次浏览 已收录 0个评论

这篇文章主要介绍了使用python实现递归版汉诺塔示例(汉诺来源gaodai#ma#com搞*!代#%^码网塔递归算法),需要的朋友可以参考下

利用python实现的汉诺塔。带有图形演示

代码如下:
from time import sleep

def disp_sym(num, sym):
        print(sym*num, end=”)

#recusion
def hanoi(a, b, c, n, tray_num):
 if n == 1:
  move_tray(a, c)
  disp(tray_num)
  sleep(0.7)

 else:
  hanoi(a, c, b, n-1, tray_num)
  move_tray(a, c)
  disp(tray_num)
  sleep(0.7)
  hanoi(b, a, c, n-1, tray_num)

def move_tray(a, b):
 for i in a:
  if i != 0:
   for j in b:
    if j != 0:
     b[b.index(j) – 1] = i
     a[a.index(i)] = 0
     return
   b.append(i)
   b.pop(0)
   a[a.index(i)] = 0
   return

def disp(tray_num):
 global a, b, c
 for i in range(tray_num):
  for j in [‘a’, ‘b’, ‘c’]:
   disp_sym(5, ‘ ‘)
   eval(‘disp_sym(tray_num – ‘ + j + “[i], ‘ ‘)”)
   eval(‘disp_sym(‘ + j + “[i], ‘=’)”)
   disp_sym(1, ‘|’)
   eval(‘disp_sym(‘ + j + “[i], ‘=’)”)
   eval(‘disp_sym(tray_num – ‘ + j + “[i], ‘ ‘)”)

  print()

 print(‘—————————————————————————‘)

tray_num=int(input(“Please input the number of trays:”))
tray=[]
for i in range(tray_num):
 tray.append(i + 1)
a=[0]*tray_num
b=a[:]
c=a[:]

a = tray[:]
disp(tray_num)
hanoi(a, b, c, tray_num, tray_num)

以上就是使用python实现递归版汉诺塔示例(汉诺塔递归算法)的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:使用python实现递归版汉诺塔示例(汉诺塔递归算法)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址