发布时间:2019-08-09 10:34:13编辑:auto阅读(2192)
#!/usr/bin/env python
# 24 - 递归 汉诺塔
# Q1:
"""
汉诺塔原型
三个柱子,64块金片
思路:
1. 将x上的63个盘子借助Z移动到Y上
2. 将Y上的63个盘子借助X移动到Z上
问题1: 将x上的63个盘子借助Z移动到Y上。拆解为:
1. 将62个盘子从x移动到Z上
2. 将最底下的第63个盘子移动到y上
3. 将z上的62个盘子移动到Y上
问题2: 将Y上的63个盘子借助X移动到Z上,拆解为:
1. 将62个盘子从y移动到x上
2. 将最底下的第63个盘子移动到z上
3. 将z上的62个盘子移动到Y上
"""
def hanoi(n,x,y,z):
if n == 1:
print(x,'--->',z)
else:
hanoi(n-1,x,z,y)# 将前n-1个盘子从x移动到y上
print(x,'--->',z)#将最底下的最后一个盘子从x移动到x上
hanoi(n-1,y,x,z)#将y上的n-1个盘子移动到z上
n = int(input('请输入汉诺塔的层数: '))
hanoi(n,'x','y','z')
上一篇: Python中list总结
下一篇: python的list去除重复
51945
51737
42034
38876
33365
30333
28975
23990
23905
22264
430°
2610°
3296°
2745°
2725°
3486°
2693°
3521°
5806°
5595°