使用Python实现汉诺塔问题示例
作者:时代&信念 时间:2022-10-22 09:17:47
前言
汉诺塔问题是一个经典的问题。汉诺塔(Hanoi Tower),又称河内塔,源于印度一个古老传说。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,任何时候,在小圆盘上都不能放大圆盘,且在三根柱子之间一次只能移动一个圆盘。问应该如何操作?
1.先谈一下什么是递归?
我自己的理解就是:将自身的问题不断减小规模,直到减小到无法减小为止。(到达递归结束条件)然后从小问题开始解决,小问题逐个解决之后,大问题也就迎刃而解了(递归回来了)
2.简而言之就是:
原问题不断减小为规模更小的原问题,然后小规模的原问题解决了,从而解决原来的大问题!
3.过程为:
减小规模、从小解决、递归回来、解决原问题!!!
4.递归的关键是:
(1)有递归结束条件。
(2)不断调用自身,减小问题规模,向递归结束条件靠拢。
汉诺塔问题
1.问题描述
有三根柱子,分别名为A,B,C。初始时,在柱子A上有n个圆盘,他们从下到上,盘子的大小是从大到小。在移动和摆放的过程中,小盘子必须在大盘子上面。 在保证规则的情况下,将柱子A上的所有盘子,移动到柱子C,移动中可以借助柱子B,但是得保证移动过程中小盘子必须得在大盘子上!!! 请打印出移动过程?
2.问题分析 递归的过程:
(1)将最上面的n-1个盘子,从A借助C移动到B
(2)将最下面的一个盘子,从A移动到C
(3)将最上面的n-1个盘子,从B借助A移动到C
递归的结束条件:
问题规模变成盘子数为0时,因为当盘子数为0时就不需要移动了!!!
3.代码(Python)
# coding:utf-8
"""
n为初始时A柱上的盘子数
a为起始盘子所在的柱子
b为中转柱子
c为目的地柱子
"""
def hanoi(n, a, b, c):
if n > 0:
hanoi(n-1, a, c, b)
print("盘子从%s移动到%s" % (a, c))
hanoi(n-1, b, a, c)
hanoi(3, "A", "B", "C")
4.结果展示
来源:https://blog.csdn.net/Elon15/article/details/125937024
标签:Python,实现,汉诺塔
0
投稿
猜你喜欢
MySQL版本低了不支持两个时间戳类型的值解决方法
2024-01-18 14:13:21
解决pycharm中导入自己写的.py函数出错问题
2023-07-09 12:12:05
jquery 禁止鼠标右键并监听右键事件
2024-02-23 14:34:19
sqlserver 2000 远程连接 服务器的解决方案
2024-01-24 03:23:12
Python3几个常见问题的处理方法
2022-08-04 10:48:56
Python使用Phantomjs截屏网页的方法
2022-06-17 15:47:14
详解python数据结构和算法
2021-06-21 13:48:19
python skimage 连通性区域检测方法
2023-04-15 00:53:40
Web标准在中国
2008-11-26 11:27:00
删除数组中重复项(uniq)
2009-12-28 12:23:00
Python数据类型转换详解
2021-03-04 04:11:13
window系统mysql无法输入和无法显示中文的解决方法
2024-01-20 05:13:29
产品交互原型设计工具分享
2010-03-24 18:06:00
django formset实现数据表的批量操作的示例代码
2023-10-10 15:20:21
virtualenv 指定 python 解释器的版本方法
2023-08-20 16:49:51
sql cast,convert,QUOTENAME,exec 函数学习记录
2024-01-23 13:53:35
Pytorch 实现变量类型转换
2021-09-27 23:35:47
python3模拟百度登录并实现百度贴吧签到示例分享(百度贴吧自动签到)
2023-07-08 23:15:23
Python实现按逗号分隔列表的方法
2023-06-08 08:32:16
python图像处理基本操作总结(PIL库、Matplotlib及Numpy)
2022-01-26 00:28:50