版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
程序设计入门Python语言……函数……第4章应用问题选讲递归算法12汉诺塔(HanoiTower)问题汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。汉诺塔问题源于印度的一个古老传说。在一块铜板装置上,有三根杆(编号A、B、C),在A杆自下而上、由大到小按顺序放置64个金盘。游戏的目标是,把A杆上的金盘全部移到C杆上,并仍按原有顺序放置好。操作规则是,每次只能移动一个盘子,并且在移动过程中三根杆上都始终保持大盘在下、小盘在上,且在三根杆之间一次只能移动一个金盘,操作过程中盘子可以置于A、B、C任一杆上。应该如何操作?汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。ABC
汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。假如A杆上只有1个金盘,则只需移动1次,可将金盘移到C杆上,记为:A—>C;假如A杆上有2个金盘:
A—>B,A—>C,B—>C假如A杆上有3个金盘:最后,借助A杆,再将B杆上的2个金盘移到C杆借助C杆,先将A杆上最上面的2个金盘移到B杆上;再将A杆上最后一个金盘移到C杆上;汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。假如A杆上只有1个金盘,则只需移动1次,可将金盘移到C杆上,记为:A—>C;假如A杆上有2个金盘:
A—>B,A—>C,B—>C假如A杆上有n个金盘最后,借助A杆,再将B杆上的n-1个金盘移到C杆借助C杆,先将最上面的n-1个金盘移到B杆上;再将A杆上的最后一个金盘移到C杆上;汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。表示:将A杆上的n个金盘,借助B杆,移到C杆构建递归函数:hanoi(n,a,b,c)def
hanoi(n,a,b,c):
ifn==1:
print("{}—>{}".format(a,c))
#将一个金盘由a移到c
else:
hanoi(n-1,a,c,b)
#借助c将n-1个金盘由a移到b
print("{}—>{}".format(a,c))#将一个金盘由a移到c
hanoi(n-1,b,a,c)
#借助a将n-1个金盘由b移到cn=int(input("请输入金盘的个数n="))print("金盘的移动顺序为:")hanoi(n,‘A’,‘B’,‘C’)
#调用函数完成求解
汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。构建递归函数:hanoi(n,a,b,c)表示:将A杆上的n个金盘,借助B杆,移到C杆汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。构建递归函数:hanoi(n,a,b,c)表示:将A杆上的n个金盘,借助B杆,移到C杆汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。构建递归函数:hanoi(n,a,b,c)表示:将A杆上的n个金盘,借助B杆,移到C杆汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。1个金盘,移动1次:A—>C2个金盘,移动3次:A—>B,A—>C,B—>C3个金盘,移动7次:(A—>C,A—>B,C—>B)
A—>C,(B—>A,B—>C,A—>C)4个金盘,移动15次;n个金盘,移动2n–1次;64个金盘,移动264–1=18446744073709551615次;假设每秒移动一次,一年是31536000秒,则一刻不停地移动完64个金盘,需要584942417355年;即使借助于计算机,假设计算机每秒能够移动1亿次,也需要大概5849年才能够完成。汉诺塔(HanoiTower)问题例4-17:编写程序,用递归算法求解汉诺塔(HanoiTower)问题。1个金盘,移动1次:A—>C2个金盘,移动3次:A—>B,A—>C,B—>C3个金盘,移动7次:(A—>C,A—>B,C—>B)
A—>C,(B—>A,B—>C,A—>C)4个金盘,移动15次;n个金盘,移动2n–1次;64个金盘,移动264
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026及未来5年中国血铅检测仪行业市场竞争态势及未来趋势研判报告
- 创新医疗器械研发的产学研生态构建
- 2026年脑机接口在运动障碍治疗中的应用前景
- 内镜活检AI算法优化:病理阳性率提升机制
- 内镜机器人穿刺的智能决策支持
- 内镜报告结构化数据在消化道药物研发中的应用
- 篮球关怀活动策划方案(3篇)
- 2026年山东省德州社区工作者考试试题题库及答案
- 内镜下器械与术式匹配
- 2026年教育创新教学方法培训
- 收心归位聚合力 实干奋进创未来总经理在2026年春节复工全体员工大会上的致辞
- 2025-2026学年北京市通州区高三(上)期末语文试卷
- 低压电工证理论试题库及答案
- 起重司索信号工培训课件
- 肥胖患者麻醉管理专家共识(2025版中国麻醉学指南与专家共识)
- 2026年湖南城建职业技术学院单招职业技能考试备考试题带答案解析
- 焦化厂电工培训课件教学
- 涉密文件销毁设备选型与管理
- 2026年南京交通职业技术学院单招职业倾向性测试题库带答案详解
- 安全随手拍活动方案
- 拆除电气施工方案
评论
0/150
提交评论