昨天看廖雪峰的Python教程,看到了递归函数,具体的递归函数看他讲的就可以,最好自己好好研究一下递归函数是干啥的,对于学习这一节有帮助,最后面有一个汉诺塔的练习题,汉诺塔简单来说就是三根柱子,A,B,C,A上面有N个盘子,比如拿三个举例子,有大中小三个盘子,然后把这三个盘子从A柱子上移动到C柱子上,在C柱子上的顺序也是大中小,这个就是简单的玩法介绍。

图一.jpg

然后思路是什么呢?整体思路就是把A柱子上的盘子分为两部分,最底下的一个盘子是一部分,剩下的盘子是一部分,那上面的例子来说就是,大号的盘子是一部分,中号和小号的是一部分,结合玩法,需要做什么呢?是不是先把中号和小号的盘子移动到B柱子上?然后在把大号盘子移动到C柱子上,最后一步就是把B柱子上的盘子全部放在C柱子上,就是整体思路

图二.png

自己可以尝试玩一下这个游戏,策略就是想办法先把A柱子上的n-1个盘子先移动到B柱子上,然后再把B柱子上的盘子想办法移动到C柱子上,总体思路就是这三步,接下来我们看代码吧:

def move(n,a,b,c):

if n == 1:

print('move',a,'-->',c)

else:

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

move(1,a,b,c)

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

函数的第一行是自定义个函数,接下来就是递归函数的结束条件,最下面就是移动盘子的步骤。

move(n-1,a,c,b)把n-1个盘子通过C移动到B;

move(1,a,b,c)把A柱子上的下面的那个盘子移动到C柱子;

move(n-1,b,a,c)把B柱子上的n-1个盘子移动到C柱子。

这个就是我们前面说的思路,三步走。

执行的结果就是:

执行结果.png

这个思路我觉得不难,对于我来说难点是什么呢?上面的运行结果一步一步怎么出来的呢?我研究了好一阵,因为我对递归函数不了解,问了其他人,查了资料,他们给我的解释是这样:

move(3,a,b,c)

move(2,a,c,b)

move(1,a,b,c) //A->C

move(1,a,c,b) //A->B

move(1,c,a,b) //C->B

move(1,a,b,c) //A->C

move(2,b,a,c)

move(1,b,c,a) //B->A

move(1,b,a,c) //B->C

move(1,a,b,c) //A->C

我对于这个我觉得看不懂,实在想不明白,为啥就会运行出来这个结果呢?函数到底一步一步怎么执行的呢?所以我就用IDE来调试这段代码,具体的运行过程是下面这样:

一.png

解释一下就是n=3的时候,函数进入了else,然后执行move(n-1,a,c,b)此时的函数参数变了,之前是a,b,c,现在是a,c,b,一定要记住这个,因为后面需要用到这个,不然理解不了。

二.png

此时n=2,又进入else的第一个函数:

三.png

打印A->C

四.png

此时需要注意参数,这个参数a,c,b,这个参数是怎么来的呢?就是第一步的解释,就是n=2的时候的参数

五.png

打印A-> B

六.png

七.png

打印C->B

八.png

九.png

打印A->C

十.png

十一.png

十二png

打印B->A

十三.png

十四.png

打印B->C

十五.png

十六.png

打印A->C

这个就是完整的步骤,一步一步对照着来,基本上就能搞明白代码具体一步一步怎么运行的:

上面总共打印了:

A->C

A->B

C->B

A->C

B->A

B->C

A->C

总结

递归的思想就是把这个目标分解成三个子目标

子目标1:将前n-1个盘子从a移动到b上

子目标2:将最底下的最后一个盘子从a移动到c上

子目标3:将b上的n-1个盘子移动到c上

然后每个子目标又是一次独立的汉诺塔游戏,也就可以继续分解目标直到N为1

python汉诺塔的求解_Python汉诺塔算法解析相关推荐

  1. python 听歌识曲_Shazam听歌识曲算法解析+python实现-3 检索歌曲

    听歌识曲是如何工作的,看完这个你就懂啦! 使用的算法是<An Industrial-Strength Audio Search Algorithm>,部分算法借鉴了Github的dejav ...

  2. python中汉诺塔如何理解_python汉诺塔问题的递归理解

    一.问题背景 汉诺塔问题是源于印度一个古老传说. 源于印度一个古老传说的益智玩具.大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘.大梵天命令婆罗门把圆盘从下 ...

  3. python logging默认情况下打印_python logging日志打印过程解析

    一. 基础使用 1.1 logging使用场景 日志是什么?这个不用多解释.百分之九十的程序都需要提供日志功能.Python内置的logging模块,为我们提供了现成的高效好用的日志解决方案.但是,不 ...

  4. python requests.get无法取出网页_Python requests获取网页常用方法解析

    这篇文章主要介绍了Python requests获取网页常用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 主要记录使用 requests ...

  5. python原生如何实现抓包_python实现抓包、解析流程,超过瘾!

    importosimportdpktimportsocketimportdatetimeimportuuidfrom scapy.sendrecv importsnifffrom scapy.util ...

  6. python终结一个循环额_Python语言入门之内存管理方式和垃圾回收算法解析

    本文主要向大家介绍了Python语言入门之内存管理方式和垃圾回收算法解析,通过具体的内容向大家展示,希望对大家学习Python语言有所帮助. 在列表,元组,实例,类,字典和函数中存在循环引用问题.有 ...

  7. 汉诺塔python创新设计_递归经典案例汉诺塔 python实现

    最近在廖雪峰大神的教程学习python 学到递归的时候有个汉诺塔的练习,汉诺塔应该是学习计算机递归算法的经典入门案例了,因此本人以为能够写篇博客来表达一下本身的看法.这markdown编辑器还不怎么会 ...

  8. 汉诺塔系列问题: 汉诺塔II、汉诺塔III、汉诺塔IV、汉诺塔V、汉诺塔VI、汉诺塔VII

    汉诺塔II:(hdu1207) /先说汉若塔I(经典汉若塔问题),有三塔,A塔从小到大从上至下放有N个盘子,现在要搬到目标C上, 规则小的必需放在大的上面,每次搬一个,求最小步数.这个问题简单,DP: ...

  9. 汉诺塔系列问题: 汉诺塔II、汉诺塔III、汉诺塔IV、汉诺塔V、汉诺塔VI

    汉诺塔 汉诺塔II hdu1207: 先说汉若塔I(经典汉若塔问题),有三塔,A塔从小到大从上至下放有N个盘子,现在要搬到目标C上, 规则小的必需放在大的上面,每次搬一个,求最小步数.这个问题简单,D ...

最新文章

  1. java拦截到登陆界面,JavaWeb 使用Filter实现自动登录
  2. oracle数据库res,ipcs、ipcrm、sysresv、kernel.shmmax
  3. a challengefor the 2 hour course
  4. 机器人学一些概念2——四元数,D-H 参数
  5. Linux学习之系统编程篇:利用 setitimer 实现 alarm练习
  6. Python3.6 deep learning first step
  7. 服务器能进系统滴滴响,ibm x226服务器开机嘀嘀嘀响三遍就没反应了。是怎么回事?内存吗?...
  8. java 锁表后事务提交_关于synchronized锁在Spring事务中进行数据更新同步,仍出现线程安全问题...
  9. 组装计算机主机心得体会,关于组装电脑的一些总结
  10. 按压式按摩靠背的设计
  11. 拳皇命运服务器维护多长时间,拳皇命运开服表
  12. Skyler2003的资源QwQ
  13. 论文笔记:Delving into Data: Effectively Substitute Training for Black-box Attack
  14. c语言5个同学三门成绩,求助:c语言 求5个同学语数外三门功课的总分与均分。大家看我错在哪了...
  15. 计算机无法打开压缩包,电脑打不开zip文件怎么打开
  16. rtx a1000相当于什么显卡 rtxa1000相当于gtx多
  17. 【游戏开发实战】Unity手游第一人称视角,双摇杆控制,FPS射击游戏Demo(教程 | 含Demo工程源码)
  18. 这可是全网EVE安装最完整,最详细的图解,没有之一【安装图解】
  19. Python:whl安装包简介与制作
  20. Excel批量替换特殊符号为符号×的操作

热门文章

  1. centos7挂载硬盘
  2. h5 加载更多下拉按钮_更好的按钮设计的5个技巧
  3. 将时间戳转换成日期格式,毫秒转时分秒
  4. Linux如何在vim里搜索关键字
  5. 使用jQuery实现点击按钮 页面下滑一定距离
  6. python建立虚拟环境virtualenv
  7. suma在c语言中表示什么变量,大学C语言程序设计考试试题及答案3套.doc
  8. Java FileWriter输出换行
  9. C++中string::相关函数【s.find()、s.npos、s.substr()、 isdigit(c)、stoi(s),erase()函数】
  10. string 中关于 npos 的使用方法详解