使用Python实现汉诺塔问题示例
作者:时代&信念 发布时间:2022-10-22 09:17:47
标签:Python,实现,汉诺塔
前言
汉诺塔问题是一个经典的问题。汉诺塔(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


猜你喜欢
- 本文为大家分享了华为校园招聘上机笔试题,供大家参考,具体内容如下[编程题] 扑克牌大小时间限制:10秒空间限制:131072K扑克牌游戏大家
- 功能:获取android设备中某一个app的cpu和内存环境:python和adb使用方法:使用adb连接android设备,打开将要测试的
- 1.消息丢失1.生产者发送失败所有消息队列都可能发生的问题生产者发送消息后,队列未成功接收(网络原因或其他)而生产者不知情,消息丢失生产者发
- 新年钟声刚过,淘宝新版首页全“心”上线了,这次设计大胆的将布局从 960px 伸展至 1000px,页面更通透,新首页更大范围的实践了 HT
- 1 Kmean图像分割按照Kmean原理,对图像像素进行聚类。优点:此方法原理简单,效果显著。缺点:实践发现对于前景和背景颜色相近或者颜色区
- 如何处理DataFrame的inf值在用DataFrame计算变化率时,例如(今天-昨天) / 昨天恰好为(2-0) / 0时,这些结果数据
- date("yyyyMMdd",time()) date() 函数功能:用于格式化时间,返回一个字符串。&nb
- 在使用 SQL Server 的过程中,用户遇到的最多的问题莫过于连接失败了。一般而言,有以下两种连接 SQL Server 的方式,一是利
- 很久没有发表文章了,最近一直在研究产品设计标准的问题,之前有发过一篇关于 Axure的教程 ,相信很多人已经学会如何使用,这次我给大家介绍一
- 这里列出了13种实现图片或网页内容 lightbox 效果的方法,大部分是链接到各种lightbox作者的英文页面,里面都有源代码下载。Th
- 起步这是许多开发者在项目初期要面临的一个普遍问题。要怎样来处理多用户类型。本文讲介绍对于不同场景和业务需求如何设计用户模型。为项目提供指导设
- 在Python数据可视化中,seaborn较好的提供了图形的一些可视化功效。seaborn官方文档见链接:http://seaborn.py
- 我们知道在Windows下多版本共存的配置方法就是改可执行文件的名字,配置环境变量。Linux中的配置原理差不多,思路就是生成软链接,配置到
- 说明本文根据https://github.com/liuchengxu/blockchain-tutorial的内容,用python实现的,
- 描述:输入一个大于0的整数n,输出1到n的全排列:例如:n=3,输出[[3, 2, 1], [2, 3, 1], [2, 1, 3], [3
- 或许现在关心交互设计的设计师们大部分来自于了互联网行业,所以我们看到当你搜索“交互设计”时更多的BLOG和文章是在谈论互联网,网站的导航,注
- swiper是我之前做前端页面会用到的一个插件,我自己认为是非常好用的。swiper提供了形式多种多样、适应各个终端的轮播图效果。本文是小编
- python绘图的包大家应该不会陌生,但是,对图的常规设置不一定会知道(其实自己也是才知道的),比如:坐标轴的字体大小、颜色设置;标题的字体
- 之前希望在手机端使用深度模型做OCR,于是尝试在手机端部署tensorflow模型,用于图像分类。思路主要是想使用tflite部署到安卓端,
- “用户体验”作为舶来品在国内风靡已经有几个年头了,而且从目前情况来看仍旧会继续风靡一段时间。当某产品发布会上,发言人张口闭口就