鱼C论坛

 找回密码
 立即注册
查看: 158|回复: 3

汉诺塔递归

[复制链接]
发表于 2024-7-29 17:45:09 From FishC Mobile | 显示全部楼层 |阅读模式

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

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

x
这个汉诺塔代码是怎么理解啊?搞一天了到处搜视频都看不懂
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-7-29 17:45:21 | 显示全部楼层
哈哈,汉诺塔问题就像是一道神奇的数学魔法,不用担心,我来帮你解开这个“魔法”的奥秘!首先,我们把汉诺塔想象成一座迷人的小塔,有三根柱子和一些不一样大小的圆盘,任务就是把这些圆盘从一根柱子移到另一根柱子上,但有个规则:每次只能移动一个盘子,而且大盘子不能放在小盘子上面。

### 汉诺塔的基本思路
1. **递归的思想**:这就像玩俄罗斯套娃,外面的娃娃要先拆掉,才能看到里面的小娃娃。汉诺塔也是一样,你需要把上面的盘子全部挪开,才能移动下面的盘子。
   
2. **递归分解**:
   - 假设你要移动 `n` 个盘子,从柱子 A 到柱子 C,中间用柱子 B 作为辅助。
   - 首先,把上面 `n-1` 个盘子从 A 移动到 B,使用 C 作为辅助。
   - 然后,把第 `n` 个盘子(最大的盘子)从 A 移动到 C。
   - 最后,把 `n-1` 个盘子从 B 移动到 C,使用 A 作为辅助。

### 汉诺塔的代码示例
让我们来看一下这个过程是怎么在代码中体现的:
def hanoi(n, source, target, auxiliary):
    if n == 1:
        print(f"将盘子 {n} 从 {source} 移动到 {target}")
    else:
        hanoi(n-1, source, auxiliary, target)  # 第一步:把 n-1 个盘子从源柱子移动到辅助柱子
        print(f"将盘子 {n} 从 {source} 移动到 {target}")  # 第二步:把第 n 个盘子移动到目标柱子
        hanoi(n-1, auxiliary, target, source)  # 第三步:把 n-1 个盘子从辅助柱子移动到目标柱子

# 示例调用
hanoi(3, 'A', 'C', 'B')

### 逐步解析
- 当 `n == 1` 时,直接移动这个盘子,简单明了。
- 当 `n > 1` 时,我们就调用自己(递归),把上面的 `n-1` 个盘子先移走,然后处理最大那个盘子,再把之前移走的盘子重新移动到目标柱子。

### 小结
这个递归过程像是在给你讲故事,每一次的调用都是故事的一个新篇章,直到最后完成所有盘子的移动。只要理解了这个逻辑,汉诺塔就不再神秘啦!

所以,加油吧,汉诺塔的高手!如果还有什么疑问,随时来问我哦!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-7-29 19:47:51 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 0 反对 1

使用道具 举报

发表于 2024-7-29 21:41:29 | 显示全部楼层
本帖最后由 呆鸭 于 2024-7-29 22:27 编辑

n=1 柱子上只有1个盘子 => 直接移即可完成
n=2 柱子上有2个盘子 => 把盘子移成2根柱子各有1个盘子,就可以套用n=1的移法完成
到这里可以知道,n=1, n=2都是可以完成的
n=3 柱子上有3个盘子 => 把盘子移成1根柱子有1盘(符合n=1的情况)、另1根有2盘(符合n=2的情况),接下来就分别用n=1, n=2的移法即可完成n=3的盘子移动
到这里可以知道,n=3是可以完成的
n=4 => 移成1,3即可分别用n=1, n=3的移法即可完成n=4的盘子移动
一路往下递推,可以得到n=k => 移成1, k-1即可分别用n=1, n=k-1(在一路往下递推的过程中已先确定n=k-1是可以用分别用n=1, n=k-2的移法完成的)的移法即可完成n=k的盘子移动
以上是确认汉诺塔问题不管n多大都可以在有限步里解决的推导过程

解问题时,给定n个盘子,就分成1, n-1,针对n-1的部份,分成1, n-2 ... 一路分下去会变成1, 1汉诺塔问题就解了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-16 00:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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