python实现汉诺塔递归算法经典案例


Posted in Python onMarch 01, 2021

学到递归的时候有个汉诺塔的练习,汉诺塔应该是学习计算机递归算法的经典入门案例了,所以本人觉得可以写篇博客来表达一下自己的见解。这markdown编辑器还不怎么会用,可能写的有点格式有点丑啦,各位看官多多见谅.

网上找了一张汉诺塔的图片,汉诺塔就是利用用中间的柱子把最左边的柱子上的圆盘依次从大到小叠上去,说白了就是c要跟原来的a一样

python实现汉诺塔递归算法经典案例

废话少说,先亮代码

def move(n, a, buffer, c):
 if(n == 1):
  print(a,"->",c)
  return
 move(n-1, a, c, buffer)
 move(1, a, buffer, c)
 move(n-1, buffer, a, c)
move(3, "a", "b", "c")

首先是定义了一个移动的函数,四个参数分别代表,a柱上的盘子个数,buffer也就是b柱,命名为buffer便于理解,顾名思义就是一个a移动到c的缓冲区.然后c就是目标柱子
下面我们来读函数代码
递归的一般写法,肯定有个中止递归循环的条件,所以在判断a柱上的盘子个数为1的时候既可以中止递归并返回,a柱上面只有一个的时候肯定就是把a移动到c了,重点是下面的代码,递归其实是一种很抽象的算法,我们要利用抽象思维去想汉诺塔这个问题,把a柱上的盘子想成两份,就是上面的盘子和最底下的盘子,如果所示

python实现汉诺塔递归算法经典案例

我们不关心上面的盘子到底有几个,我们每次的操作就是把最底下的盘子通过缓冲区 b柱 buffer 移动到c柱。
童鞋们肯定在想为啥要酱紫移动呢,其实这是一种总结归纳吧,你自己玩一下汉诺塔游戏就会发现规律,其实这个游戏就是不停的把上面的所有的想方设法的移到b上,然后把a最后最大的那个弄到c,然后再绞尽脑汁的把b上的移动到c,这时候你就发现,原来b上的也要先通过空的也就是a来存放当前b上面的n-1个,然后把b的最大最后的移动到c,这里规律就体现出来了,也可以抽象出移动的方法,并可以以此设计出程序算法.

以下我们来利用刚才的抽象思维解读剩余代码

move(n-1, a, c, buffer)

这段代码就是表示把刚才所说的a柱的上面的n-1个,通过c按照从小到大的规则先移动到缓冲区buffer。此函数进入递归。

move(1, a, buffer, c)

当上面的语句执行完成,也就是n-1个盘子的递归移动完成之后,执行此语句,就是把a柱上的一个盘子移动到c,也就是所谓的最底下的盘子

move(n-1, buffer , a, c)

最后一步,就是刚才把a上面的n-1个都移动到了buffer上面,肯定要通过a移动到c才能完成整个汉诺塔的移动啊,于是最后一步自然是把刚才的n-1个通过a当缓冲区移动到c柱上.
我来写下整个移动流程,以a柱上有3个为例子

/**
我把3个盘子的汉诺塔全部通过代码演示,按缩进原则,每一个缩进即进一个递归函数,每打印一次即中止当前递归,也就是每个print
说明:
 1.n = 3, n = 2, n = 1是每次执行if(n == 1)的结果,这里就不写判断了,相信童鞋们也能看懂,也就是n不等与1时就减1进入递归
 2.请注意a,b,c柱每次进入函数的顺序,不要被形参带错路了,看准每次函数参数的实参 
**/
move(3, "a", "b", "c")
n=3:
 //开始从a上移动n-1即2个盘子通过c移动到b,以腾出c供a最后一个盘子移动
 move(2, "a","c","b")
 n=2:
 //开始进行n=2的一个递归,把当前a('a')柱上的n-1个盘子通过c('b')移动到b('c')
  move(1, "a", "b", "c")
  n=1:
  //n=2的第一个递归完成,打印结果,执行当前子函数剩余代码
   print("a", "->", "c") 
  move(1, "a", "c", "b")
  n=1:
   print("a", "->", "b")
  move(1, "c", "a", "b")
  n=1:
   print("c", "->", "b")
   //到这里完成了a柱上面的n-1即是2个盘子的移动
//开始把a柱上最后一个盘子移动到c柱上
move(1, "a", "b", "c")
n=1:
 print("a", "->", "c")
 //到这里完成移动a柱上的最后一个盘子到c柱上 
move(2, "b", "a", "c")
n=2:
//开始进行n=2的第二个递归,即把当前b('b')的盘子(n-1个)通过a('a')移动到c('c')上
 move(1, "b", "c", "a")
 n=1:
 //n=2 的第二个递归完成,打印结果并执行当前子函数的剩余代码
  print("b", "->", "a")
 move(1, "b", "a", "c")
 n=1:
  print("b", "->", "c")
 move(1, "a", "b", "c")
 n=1:
  print("a", "->", "c")
  //到这里把b上的盘子通过a移动到c,
//整个代码执行完毕,汉诺塔移动完成

最后的打印结果为:

python实现汉诺塔递归算法经典案例

童鞋们理解了汉诺塔的递归算法原理后,可以写个程序来试试,这里只是学到Python的递归所以用了Python,童鞋们可以用其他语言实现,汉诺塔确实能帮助理解递归原理,递归在程序设计中的重要性不言而喻啦!

Python 相关文章推荐
Python创建xml的方法
Mar 10 Python
Python中操作mysql的pymysql模块详解
Sep 13 Python
python基于pyDes库实现des加密的方法
Apr 29 Python
Python对文件和目录进行操作的方法(file对象/os/os.path/shutil 模块)
May 08 Python
python验证码识别实例代码
Feb 03 Python
python生成九宫格图片
Nov 19 Python
Django框架实现分页显示内容的方法详解
May 10 Python
Python人工智能之路 之PyAudio 实现录音 自动化交互实现问答
Aug 13 Python
Django对models里的objects的使用详解
Aug 17 Python
Python大数据之网络爬虫的post请求、get请求区别实例分析
Nov 16 Python
Python爬虫简单运用爬取代理IP的实现
Dec 01 Python
Python Pygame实战在打砖块游戏的实现
Mar 17 Python
python中list列表的高级函数
May 17 #Python
python模拟Django框架实例
May 17 #Python
python采用django框架实现支付宝即时到帐接口
May 17 #Python
图文详解WinPE下安装Python
May 17 #Python
Windows下Eclipse+PyDev配置Python+PyQt4开发环境
May 17 #Python
Windows下搭建python开发环境详细步骤
Jul 20 #Python
Win7下搭建python开发环境图文教程(安装Python、pip、解释器)
May 17 #Python
You might like
两个php日期控制类实例
2014/12/09 PHP
php图像处理函数imagecopyresampled用法详解
2016/12/02 PHP
PHP + plupload.js实现多图上传并显示进度条加删除实例代码
2017/03/06 PHP
PHP实现广度优先搜索算法(BFS,Broad First Search)详解
2017/09/16 PHP
jQuery TextBox自动完成条
2009/07/22 Javascript
Dom 结点创建 基础知识
2011/10/01 Javascript
解决Extjs 4 Panel作为Window组件的子组件时出现双重边框问题
2013/01/11 Javascript
js实现的切换面板实例代码
2013/06/17 Javascript
基于Bootstrap的Metronic框架实现条码和二维码的生成及打印处理操作
2016/08/29 Javascript
EasyUI创建人员树的实例代码
2017/09/15 Javascript
帝国cms首页列表页实现点赞功能
2017/10/30 Javascript
JS实现DOM删除节点操作示例
2018/04/04 Javascript
vue-cli构建vue项目的步骤详解
2019/01/27 Javascript
Vue $mount实战之实现消息弹窗组件
2019/04/22 Javascript
微信小程序项目总结之记账小程序功能的实现(包括后端)
2019/08/20 Javascript
angularjs自定义过滤器demo示例
2019/08/24 Javascript
Python2.x版本中cmp()方法的使用教程
2015/05/14 Python
Python探索之修改Python搜索路径
2017/10/25 Python
Python实现字典的遍历与排序功能示例
2017/12/23 Python
Python读取图片为16进制表示简单代码
2018/01/19 Python
Python 判断 有向图 是否有环的实例讲解
2018/02/01 Python
Python创建一个空的dataframe,并循环赋值的方法
2018/11/08 Python
python 定时任务去检测服务器端口是否通的实例
2019/01/26 Python
pybind11和numpy进行交互的方法
2019/07/04 Python
python读取图片的几种方式及图像宽和高的存储顺序
2020/02/11 Python
Python基于Socket实现简单聊天室
2020/02/17 Python
浅谈html5 响应式布局
2014/12/24 HTML / CSS
网购亚洲时装、美容产品和生活百货:YesStyle
2016/09/15 全球购物
麦德龙官方海外旗舰店:德国麦德龙超市
2017/12/23 全球购物
Crabtree & Evelyn英国官网:瑰珀翠护手霜、香水、沐浴和身体护理
2018/04/26 全球购物
The Kooples美国官方网站:为情侣提供的法国当代时尚品牌
2019/01/03 全球购物
专科毕业生自我鉴定
2013/12/01 职场文书
竞选学生会主席演讲稿
2014/04/24 职场文书
暑期教师培训方案
2014/06/07 职场文书
十佳标兵事迹材料
2014/08/18 职场文书
跑出一片天观后感
2015/06/08 职场文书