位置: 编程技术 - 正文

python实现汉诺塔递归算法经典案例(python 汉诺塔)

编辑:rootadmin

推荐整理分享python实现汉诺塔递归算法经典案例(python 汉诺塔),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python 汉诺塔,用python写汉诺塔程序,python5.7汉诺塔,汉塔诺python方法,用python写汉诺塔,python5.7汉诺塔,用python编写一个汉诺塔的移动函数,汉塔诺python方法,内容如对您有帮助,希望把文章链接给更多的朋友!

学到递归的时候有个汉诺塔的练习,汉诺塔应该是学习计算机递归算法的经典入门案例了,所以本人觉得可以写篇博客来表达一下自己的见解。这markdown编辑器还不怎么会用,可能写的有点格式有点丑啦,各位看官多多见谅.  网上找了一张汉诺塔的图片,汉诺塔就是利用用中间的柱子把最左边的柱子上的圆盘依次从大到小叠上去,说白了就是c要跟原来的a一样

废话少说,先亮代码

  首先是定义了一个移动的函数,四个参数分别代表,a柱上的盘子个数,buffer也就是b柱,命名为buffer便于理解,顾名思义就是一个a移动到c的缓冲区.然后c就是目标柱子 下面我们来读函数代码  递归的一般写法,肯定有个中止递归循环的条件,所以在判断a柱上的盘子个数为1的时候既可以中止递归并返回,a柱上面只有一个的时候肯定就是把a移动到c了,重点是下面的代码,递归其实是一种很抽象的算法,我们要利用抽象思维去想汉诺塔这个问题,把a柱上的盘子想成两份,就是上面的盘子和最底下的盘子,如果所示

 我们不关心上面的盘子到底有几个,我们每次的操作就是把最底下的盘子通过缓冲区 b柱 buffer 移动到c柱。  童鞋们肯定在想为啥要酱紫移动呢,其实这是一种总结归纳吧,你自己玩一下汉诺塔游戏就会发现规律,其实这个游戏就是不停的把上面的所有的想方设法的移到b上,然后把a最后最大的那个弄到c,然后再绞尽脑汁的把b上的移动到c,这时候你就发现,原来b上的也要先通过空的也就是a来存放当前b上面的n-1个,然后把b的最大最后的移动到c,这里规律就体现出来了,也可以抽象出移动的方法,并可以以此设计出程序算法.

 以下我们来利用刚才的抽象思维解读剩余代码

python实现汉诺塔递归算法经典案例(python 汉诺塔)

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

这段代码就是表示把刚才所说的a柱的上面的n-1个,通过c按照从小到大的规则先移动到缓冲区buffer。此函数进入递归。

move(1, a, buffer, c)

当上面的语句执行完成,也就是n-1个盘子的递归移动完成之后,执行此语句,就是把a柱上的一个盘子移动到c,也就是所谓的最底下的盘子

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

最后一步,就是刚才把a上面的n-1个都移动到了buffer上面,肯定要通过a移动到c才能完成整个汉诺塔的移动啊,于是最后一步自然是把刚才的n-1个通过a当缓冲区移动到c柱上.  我来写下整个移动流程,以a柱上有3个为例子

最后的打印结果为:

童鞋们理解了汉诺塔的递归算法原理后,可以写个程序来试试,这里只是学到Python的递归所以用了Python,童鞋们可以用其他语言实现,汉诺塔确实能帮助理解递归原理,递归在程序设计中的重要性不言而喻啦!

批处理与python代码混合编程的方法 批处理可以很方便地和其它各种语言混合编程,除了好玩,还有相当的实用价值,比如windows版的rubygem包管理器就是运用了批处理和ruby的混合编写,batho

bat和python批量重命名文件的实现代码 最近从某网站下载了一批文档,但是文件是用数字串命名的文档(很多图书馆都这样吧),现在我也下载完了这些文件,也有这些文件的列表,就是不

python列表的常用操作方法小结 本文实例为大家了Python中列表(List)的详解操作方法,供大家参考,具体内容如下1.创建列表。只要把逗号分隔的不同的数据项使用方括号括起来即可List=[

标签: python 汉诺塔

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

上一篇:python中list列表的高级函数(python里list)

下一篇:批处理与python代码混合编程的方法(python运行批处理文件)

  • 财税2019 21号第二条
  • 报税扣款锁定如何解除
  • 国税纳税标准
  • 缴纳工会经费会计处理
  • 每年税控盘维护费会计分录
  • 发票用完了领发票需要带什么东西
  • 退税发票误勾选怎么撤销
  • 资产总计是期初余额吗
  • 利润表中第3栏营业税金及附加等于什么
  • 支付境外软件服务怎么用
  • 存货盘盈属于什么活动
  • 房产订金是否缴纳土地增值税?
  • 变更财务负责人在网上变更流程
  • 电子发票二维码怎么下载
  • 转让地下建筑物交土地增值税吗
  • 认缴制下实收资本可以一直为零吗
  • 企业核销应收账款需要什么资料
  • 企业所得税是根据什么申报的
  • 企业所得税固定资产折旧计算
  • 劳务费和服务费一样吗
  • 一年内到期的应付债券计入
  • 银行利息为什么只算10个月
  • 当月制造费用转生产成本
  • window的hosts文件
  • 如何将win11任务栏变小一点
  • 苹果手机抖音投屏到电视怎么投屏
  • linux安装常用命令
  • 怎么将电脑硬盘做成移动硬盘
  • 融资租赁与经营租赁的区别主要是
  • 捐赠支出税前扣除条件
  • macos big sur值得升级吗
  • 坏账损失税务处理
  • php 抓取别的网站的内容
  • yolov5m
  • 房产税为什么会退税
  • 分配利润的会计处理
  • 【AutoGPT】你自己运行,我先睡了—— ChatGPT过时了吗?
  • php服务器地址怎么填
  • 物流公司主营业务怎么写
  • 公司出现质量问题员工怎么处理
  • rust 前端开发
  • 小规模纳税企业在应交增值税明细科目
  • 差额冲账法
  • 金税盘清卡失败增值税未申报或未比对
  • 个体工商户怎么变更法人
  • 一步一步的简单
  • db2 798
  • 票种核定啥意思
  • 取得交易性金融资产支付的相关税费计入
  • 事业单位资产负债表自动转帐
  • 企业所得税季度预缴纳税申报表
  • 赔偿给客户的产品交增值税吗
  • 亏损企业对外捐赠的税前扣除
  • 银行承兑汇票是什么意思
  • 税费滞纳金计入营业外支出吗
  • 固定资产报废如何进行账务处理
  • 电子发票不小心删掉了怎么办
  • 转账支票的特点有哪些
  • 在你登陆时发生了问题
  • 暂估入库后发票来不了会计分录
  • 会计备注一般写什么
  • sql语句大全实例教程
  • mssql insert into 和insert into select性能比较
  • win7 64位系统中使用音乐播放器播放音乐很卡该怎么办?
  • 快启动U盘怎么进去
  • windoes版本
  • wysafe.exe是什么
  • Win7笔记本突然wifi功能没了
  • win10提醒功能
  • linux中安装软件可使用哪些方式
  • js自动执行点击事件
  • css制作排行榜
  • 狗刨好学吗
  • 通过Tabs方法基于easyUI+bootstrap制作工作站
  • python字典x in d
  • 改税务报表会有限风险吗
  • 如何开具分包发票流程
  • 税率的分类有哪些
  • 在深圳月薪8000是什么水平
  • 买新车的注意事项有哪些比较重要的
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设