博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python递归——汉诺塔
阅读量:6802 次
发布时间:2019-06-26

本文共 975 字,大约阅读时间需要 3 分钟。

汉诺塔的传说

法国数学家曾编写过一个印度的古老传说:在世界中心贝拿勒斯(在印度北部)的圣庙里,一块黄铜板上插着三根宝石针。印度教的主神在创造世界的时候,在其中一根针上从下到上地穿好了由大到小的64片金片,这就是所谓的汉诺塔。不论白天黑夜,总有一个僧侣在按照下面的法则移动这些金片:一次只移动一片,不管在哪根针上,小片必须在大片上面。僧侣们预言,当所有的金片都从梵天穿好的那根针上移到另外一根针上时,世界就将在一声霹雳中消灭,而、庙宇和众生也都将同归于尽。

  不管这个传说的可信度有多大,如果考虑一下把64片金片,由一根针上移到另一根针上,并且
始终保持上小下大的顺序
  这需要多少次移动呢?这里需要递归的方法。假设有n片,移动次数是f(n).显然f(1)=1,f(2)=3,f(3)=7,且f(k+1)=2*f(k)+1。此后不难证明
f(n)=2^n-1。n=64时,
假如每秒钟一次,共需多长时间呢?一个平年365天有31536000 秒,闰年366天有31622400秒,平均每年31556952秒,计算一下:
  18446744073709551615秒
  这表明移完这些金片需要
5845.54亿年以上,而地球存在至今不过45亿年,太阳系的预期寿命据说也就是数百亿年。真的过了5845.54亿年,不说太阳系和银河系,至少地球上的一切生命,连同梵塔、庙宇等,都早已经灰飞烟灭。

 

python汉诺塔

#函数的递归算法 汉诺塔游戏def hanoi(n,x,y,z):    if n==1:        print(x,'-->',z)    else:        hanoi(n-1,x,z,y)#将前n-1个盘子从x移动到y上        hanoi(1,x,y,z)#将最底下的最后一个盘子从x移动到z上        hanoi(n-1,y,x,z)#将y上的n-1个盘子移动到z上n=int(input('请输入汉诺塔的层数:'))hanoi(n,'x','y','z')》请输入汉诺塔的层数:3x --> zx --> yz --> yx --> zy --> xy --> zx --> z

 

 

转载于:https://www.cnblogs.com/1906859953Lucas/p/8986801.html

你可能感兴趣的文章
今日小结 4.16
查看>>
05 配置优化器
查看>>
输入的整数反方向输出
查看>>
[ Nowcoder Contest 167 #C ] 部分和
查看>>
MFC 中CFileDialog的用法
查看>>
关于SVM一篇比较全介绍的博文
查看>>
English - because of,due to ,thanks to ,owing to ,as a result of ,on account of解析
查看>>
全球免费开放的电子图书馆
查看>>
27_Blog Reader
查看>>
个人代码库のC#可移动按钮“相关代码”
查看>>
MyBatis配置项--配置环境(environments)--databaseIdProvider
查看>>
类、对象、方法、实例方法、类方法
查看>>
《CLR via C#》读书笔记 之 目录导航
查看>>
51Nod 1009:1009 数字1的数量 (思维)
查看>>
Spring下载地址
查看>>
SQL性能优化总结
查看>>
WinHex数据恢复笔记(二)
查看>>
c#设计模式系列:观察者模式(Observer Pattern)
查看>>
NO23 Linux正则表达式结合三剑客企业级实践--取IP
查看>>
Max user processes limits
查看>>