位置: 编程技术 - 正文

[置顶] 汉诺塔的原理剖析以及递归的解决办法

编辑:rootadmin

推荐整理分享[置顶] 汉诺塔的原理剖析以及递归的解决办法,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

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

如果移动一个圆盘需要1秒钟的话,等到个圆盘全部重新落在一起,宇宙被毁灭是什么时候呢?

让我们来考虑一下个圆盘重新摞好需要移动多少次吧。1个的时候当然是1次,2个的时候是3次,3个的时候就用了7次......这实在是太累了

因此让我们逻辑性的思考一下吧。

3个的时候能够移动最大的3盘时如图所示。

到此为止用了7次。

接下来如右图,在上面再放上3个圆盘时还要用7次(把3个圆盘重新放在一起需要的次数)。[2]

因此,4个的时候是

“3个圆盘重新摞在一起的次数”&#;1次&#;“3个圆盘重新摞在一起需要的次数”

=2x“3个圆盘重新摞在一起的次数”&#;1次

=次。

那么,n个的时候是

[置顶]
        汉诺塔的原理剖析以及递归的解决办法

2x“(n-1)个圆盘重新摞在一起的次数”&#;1次。

由于1个的时候是1次,结果n个的时候为(2的n次方减1)次。

1个圆盘的时候2的1次方减1

2个圆盘的时候2的2次方减1

3个圆盘的时候2的3次方减1

4个圆盘的时候2的4次方减1

5个圆盘的时候2的5次方减1

........

n个圆盘的时候2的n次方减1

也就是说,n=的时候是(2的次方减1)次。

因此,如果移动一个圆盘需要1秒的话,

宇宙的寿命=2的次方减1(秒)

2的次方减1到底有多大呢?动动计算器,答案是一个二十位的数字约是

1.*^

用一年=秒x分x小时x天来算的话,大约有亿年吧。

太阳及其行星形成于亿年前,其寿命约为亿年。

由此可见,该问题是一个世界性的难题。那么接下来我们用c#解决一下,源码如下:

using UnityEngine;using System.Collections;public class Script1 : MonoBehaviour { int aa=0; void hannuota(string a,string b,string c,int n){ if (n > 1) { hannuota (a,c,b,n-1); Debug.Log(a&#;"-->"&#;c); aa&#;&#;; hannuota (b,a,c,n-1); } else{ Debug.Log(a&#;"-->"&#;c); aa&#;&#;; } } void Start(){ hannuota("1","2","3",4); Debug.Log (aa); }}

Unity中自动寻路的几种方法(二) 前面以及讲过A星寻路的大体实现方法,除了A星寻路之外,还有很多类的寻路方案,itween插件就可以实现简单的寻路方案,下面就一个小案例来简要得讲

(Unity)NGUI 按钮的禁用 该文主要研究NGUI中的一组按钮,当一个按钮按下同时禁用掉其他按钮原理:NGUI的控件的交互都少不了BoxCollider的主击触发,故要想禁用掉按钮很简单,

unity3d android 插件 参考自unity官方文档,点击传送方法1首先在unity的assets目录下创建Plugins目录结构,具体如图bin目录里面存放已经打包好了的xxx.jar包(这里也可以在Android目录

标签: [置顶] 汉诺塔的原理剖析以及递归的解决办法

本文链接地址:https://www.jiuchutong.com/biancheng/380217.html 转载请保留说明!

上一篇:Unity3D深入浅出 - Shader基础开发(unity3ds)

下一篇:Unity中自动寻路的几种方法(二)(unityai寻路)

  • 小规模纳税人收普票和专票有什么区别
  • 进项税额转出就是要多交税吗
  • 滞留票有什么影响
  • 金税四期什么时候正式上线
  • 技术服务费3%
  • 机器配件属于什么报销项目
  • 5000以下固定资产怎么做账
  • 预付账款收不回发票怎么核销
  • 退税发票误勾选确认
  • 做账要不要入库单和出库单
  • 电子产品配件批发市场
  • 购买办公用品并分发有关部门会计分录
  • 房地产土地增值税优惠政策
  • 应收银行存款利息怎么算
  • 银行付款退回重新开户
  • 公司向股东借款计入什么科目
  • 代销产品缴纳增值税吗
  • 私车公用保险费用公司承担吗
  • 营改增后餐饮业税率
  • 租赁车辆维修费谁承担
  • 有限合伙人企业人数
  • 税率开错跨月没法收回
  • 公司没有员工怎么零申报
  • 支付宝对公账户还款清零要多久
  • 房地产企业预付账款为负数
  • 进货价加多少卖不亏增值税
  • 事业单位是否需要章程
  • 低值易耗品属于资产类
  • 企业微信收入也要交税吗
  • 咨询费的税费
  • 个人独资企业生活费用扣除
  • 苹果Mac系统怎么用光盘安装
  • 今年利润弥补以后怎么算
  • ajax调用php函数
  • php入门课程
  • sci期刊投稿步骤
  • 支付宝小程序跳回app
  • 外币借款业务的特点包括
  • 训练自己的GPT模型 中文改英文
  • 增值税发票打印出格了能用吗
  • 未确认融资费用账务处理
  • 织梦怎样实现文件上传
  • mongodb建立索引的命令
  • nosql manager for mongodb
  • 电商企业快递费怎么算
  • 所得税申报表收入包含营业外收入吗
  • 商誉的会计核算怎么核算
  • SqlServer 2005 T-SQL Query 学习笔记(1)
  • 增值税少企业所得税高吗
  • 纳税申报是根据什么填写的
  • 实际成本法下采购材料的会计分录
  • 银行承兑汇票和银行汇票的区别
  • 一般纳税人季报还是月报
  • 亏损企业对外捐赠的税前扣除
  • 固定资产增值税发票如何入账
  • 企业发生的各项罚款收入应计入
  • 计提员工工资是什么意思
  • 固定资产报废如何记账
  • 小规模纳税人变更一般纳税人条件
  • 会计利润是利润加暂时性差异吗为什么
  • 新企业如何建帐
  • mysql日志的作用
  • php连接mysql数据库的几种方式及区别
  • 如何查看文件系统
  • win8网页打不开
  • ubuntu系统防火墙状态
  • 无需u盘安装系统
  • win10通过任务管理器打开设置
  • spes监控原理
  • perl 批量注释
  • cocos2dx游戏开发
  • 分页jsp
  • using dispose
  • 全面理解和准确把握新时代党的建设总要求心得体会
  • js设计模式和开发实践
  • 浙江公务员冬令时上班时间
  • 一般纳税人出租房屋增值税税率
  • 行政事业单位的会计核算以什么为基础
  • 乡镇四所是指哪些所
  • 公司租房的房产税应计入哪个科目
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设