博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
64层的汉诺塔问题究竟需要几步才能完成?
阅读量:2059 次
发布时间:2019-04-29

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

汉诺塔

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

由来

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

演示

用Python来演示一下:

代码

count = 0def hanoi(n, a, b, c):    global count    if n == 1:        count += 1    else:        hanoi(n - 1, a, c, b)        hanoi(1, a, b, c)        hanoi(n - 1, b, a, c)hanoi(n, 'A', 'B', 'C')print(count)
n count
1 1
2 3
3 7
4 15
5 31
20 1048575

可以看出count = 2n-1,当n = 64时,count = 264 - 1 = 18,446,744,073,709,551,615,假如一秒一步,平年31536000秒,闰年31622400秒,也就是说需要584,554,049,253.85542985900539443733年也就是5845.54亿年才能完成 ,也许那时人类早就不在太阳系了。

转载地址:http://fbolf.baihongyu.com/

你可能感兴趣的文章
AJAX 设计制作 在公司弄的 非得要做出这个养的 真晕!
查看>>
AJAX 自己研究玩的
查看>>
javascript(js)数组操作
查看>>
用JavaScript脚本实现Web页面信息交互
查看>>
window 窗口对象操作
查看>>
公司一位老员工愤然离去的留信!崩溃!
查看>>
C#技巧:网页表单自动填写技术(以gmail为例)
查看>>
C#基础概念二十五问
查看>>
C#在Excel中将连续多列相同数据项合并
查看>>
C#如何把html中的相对路径变成绝对路径
查看>>
用C#编写发手机中文短信息Windows服务
查看>>
C#的四个基本技巧
查看>>
编程实例 使用C#的BitmapData
查看>>
区分Oracle和SQL Server常用函数调用方法
查看>>
详解Visual C#数据库基本编程
查看>>
第一个C#应用程序
查看>>
第一章C#简介
查看>>
NGWS runtime 技术基础
查看>>
Linux find 文件查询 用法示例
查看>>
Linux 查看文件大小
查看>>