【python】99%的人做过这道题都哭了,我试过,是真的

正经标题:汉诺塔问题解析与递归函数

在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。
在python里可以用递归函数优雅的解决汉若塔问题

汉诺塔:汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。

代码:

>>>def move(n,a,b,c):  
...    if n==1:  
...        print(a,'-->',c)  
...    else:  
...        move(n-1,a,c,b)   #将前n-1个盘子从a移动到b上  
...        move(1,a,b,c)     #将最底下的最后一个盘子从a移动到c上  
...        move(n-1,b,a,c)   #将b上的n-1个盘子移动到c上  
>>> move(3,'A','B','C')  
A --> C
A --> B
C --> B
A --> C
B --> A
B --> C
A --> C

分析一下应该是这样:
懂的玩这个的人知道规律是,柱子分为起始柱子,跳板柱子,目标柱子
“宏观”看,目标是借助跳板柱子,把起始柱子n个圈弄到目标柱子:用move(n,a,b,c) 代表这个大步骤,a是起始,中间参数b是跳板,c是目标。总之假设move(n,a,b,c) 就是代表能办成这事的标准
具体如何办到?

  • 大了看分三步:
    第一步是把n-1个a借助c弄到b,所以递归同理第一步就是 move(n-1,a,c,b)
    第二步是把最底下这个a弄到c,move(1,a,b,c)
    第三步将b上的n-1个盘子移动到c上,move(n-1,b,a,c)
    打开冰箱,放进大象,关掉冰箱,搞定!
    这里的abc应解读为起始柱子,跳板柱子,目标柱子。
  • 小了看都是这三步:
    比如第一步怎么能把n-1个a弄到b,第一(1)步就是,把n-2个a弄到c:move(n-2,a,b,c);第一(2)步是把最后一个a弄到b:....底下就知道怎么回事了。
  • 关键输出步骤是n=1的时候,也就是 起始柱子-->目标柱子 在标准move(n,a,b,c) 里,就是print(a,'-->',c) ,注意不是('A''-->''C')。

拆分过程看看:

拆分过程看看.png

感觉递归函数很好用,像是把一头大象在宏观上分解成合乎共同逻辑的关键几大块。先切出大块,再递归循环下去,按照切大块的方法把每一个大块切成小块,都切到n=1的时候,就能把大象吃了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容

  • 题目: 汉诺塔的移动可以用递归函数非常简单地实现。 请编写move(n, a, b, c)函数,它接收参数n,表示...
    快乐的杀马特阅读 451评论 0 0
  • 最近在慕课网学习廖雪峰老师的Python进阶课程,做笔记总结一下重点。 基本变量及其类型 变量 在Python中,...
    victorsungo阅读 1,654评论 0 5
  • 什么是函数 我们知道圆的面积计算公式为: S = πr² 当我们知道半径r的值时,就可以根据公式计算出面积。假设我...
    _王子_阅读 547评论 0 2
  • 今天星期天,尹秀鑫休息的第二天,今天作业都写完了,晚饭过后,我给她检查作业,数学作业口算天天练,她共做了八页,错了...
    地球与我同在阅读 157评论 0 0
  • “设计”——暗含了可以预先对组成单元进行规划的意思,“兵马未动,粮草先行”体现了前人在规划事情的聪明才智。但是数据...
    悟成阅读 12,284评论 0 56