鱼C论坛

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

[学习笔记] 024递归:汉诺塔

[复制链接]
发表于 2017-6-29 22:37:00 | 显示全部楼层 |阅读模式

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

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

x
1.汉诺塔的由来:汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。
2.汉诺塔游戏的规则与编程剖析
假设汉诺塔有x,y,z三根柱子,已知柱子x上有n个盘子,盘子大小各不相同呈金字塔状放置;要求将n个盘子从柱子x上移到柱子z上,条件是每次只能移到一个盘子,而且必须永远是大盘子在下小盘子在上的移到状态。
将n个盘子从柱子x移到柱子z上,无法直接实现该过程,需借助柱子y;
①首先,将柱子x上的n-1个盘子移动到柱子y上;
②然后,将柱子x上最后一个盘子移动到柱子z上;
③最后,将柱子y上的n-1个盘子移动到柱子z上。
3.用递归方法编写汉诺塔游戏程序
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移动到z上
        hanoi(n-1, y, x, z) #将y上的n-1个盘子移动到z上

n = int(input('请输入汉诺塔的层数:'))
hanoi(n, 'x', 'y', 'z')

评分

参与人数 1荣誉 +3 鱼币 +5 收起 理由
小甲鱼 + 3 + 5 支持楼主!

查看全部评分

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-6-29 22:40:14 | 显示全部楼层
支持一个!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 17:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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