Hanoi问题的非递归算法分析.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Hanoi问题的非递归算法分析.doc

Hanoi问题的非递归算法分析 第6卷第2期 20O6年6月 兰州石化职业技术学院 JournalofI.~OUPetrochemicalCollegeofTechnology Vo1.6No.2 Jun.,20O6 文章编号:1671—4067(2006)02—0038—03 Hanoi问题的非递归算法分析 孙泽宇,丁国强,舒云星 (洛阳工业高等专科学校计算机系,河南洛阳471003) 摘要:Hanoi(汉诺)塔问题作为一个古典的数学问题,一直以来都是数据结构中递归算 法的经典案例,在对汉诺塔问题递归算法进行研究与分析后,提出一种占据内存更少,速 度更快且实现简单的非递归算法. 关键词:汉诺塔;递归;非递归;时闻复杂性 中图分类号:0141.3文献标识码:A 主.在对递推算法和递归算法的研究与分析后,提 O引言出了一种非递归算法. 汉诺塔示意图如图1所示. 长期以来,解决汉诺塔问题都是以递归算法为 A 1汉诺塔非递归算法思想 BC 图1Hanoi塔问题示意图 1.1应考虑的四个问题 对于在编写汉诺塔问题非递归算法时,应考虑 到四个问题uJ: 1)在每次移动一个盘的过程中尽可能移动直 径大的盘,即两盘均可移动时优先移动直径大的盘. 2)不允许将刚移到某针上的盘立即移回去,即 不允许来回移动一个盘. 3)直径最小的盘只能从A针移到B针;由B针 移到C针;由C针移到A针. 4)保证小直径的盘一定在大直径的盘之上. 收稿日期:2O06—04—12 作者简介:孙泽宇(1977一),男,吉林长春人,助教;舒云星(1962 一 ),男,江苏南通人,教授.博士. 在非递归算法中第1)条是为汉诺塔提供了结 束的条件.第2)条是防止机器出现死循环.第3) 条则把有序的C针变成了周而复始的C针,且每次 只能移动一个确定的盘子. 1.2解决问题的方案 (1)设有N个盘子按照规则从第1针移动到第 3针所需要的最少操作数为An,则根据汉诺塔的递 归性和对称性可知,数列{A.}须满足:A=1时,而 当n≥2时有An=2A一1+1,由A=2A一1+1可得 A川=2(A+1)这说明数列{A}以2为公比而 以A.+1=2为首项的等比数列,所以+=2枣 2(n≥1),即A.=2一1(n≥1).所以解决N个 盘子的汉诺塔问题至少需要2一1步操作呤】.例如 当N=4时,汉诺塔游戏过程如表1所示. 孙泽宇,丁国强,舒云星.Hanoi问题的非递归算法分析?39? 表1N=4时汉诺塔游戏移动过程表 BCABCABCABCABCABCABCABC 1 2 3 (7) ABCABCABCABCABCABCABCAB 1 2 3 (8) 2 3 14 (14)(15) 可见,通过此表的移动过程可以看出,当N=4 时,共移动l5步才能完成上述操作.即当N个盘 子时共要移动2一1步才能完成N个盘子的操作. 2)根据汉诺塔的对称性原理可知处于中心位 置的那一步的操作对象是N号盘,前一半操作和后 一 半操作的操作对象是关于中心对称,因此只要确 定出前一半操作的操作对象,那么后一半操作的操 作对象也就随之确定了.而前一半操作的操作对象 又是解决前N一1个盘子的汉诺塔问题.因此处于 这一半的中心位置的那一步的操作对象就应该是N 一 1号盘,如此继续下去,每一步的操作对象都可以 确定下来. 3)处于中心位置的那一步的操作对象是N号 盘,起点是A针,终点是C针,前一半操作是将前N 一 1个盘子从A针移到B针的.因此,处于这一半 的中心位置的那一步的操作对象是N一1号盘,起 点是A针,终点是B;后一半操作是将前N一1个盘 子从B针移到C针的.因此,处于这一半的中心位 置的那一步的操作对象是N一1号盘,起点是B针, 终点是C针.按照这种方式,从中心位置开始,逐 渐向两瑞扩展,最终能够确定所有操作步起点和终 点. 2算法的实现一6 利用函数调用法来实现汉诺塔非递归算法 voiddele(intm,inta); main() {intn,m=1,i; inta; prinff(pleaseinputthenumberofdisks:\n); scanf(%d,amp;n); fl0r(i-2;ilt;=n;i++) m=m2+1; dele(m,a); m=2m; fl0r(i=1;ilt;=m;i++,i++) priIltf(%da%d\n,a[i],a[i+1]); } 下面以N=4为例,写出汉诺塔问题非递归算 法的完整程序 1)上机测试程序 #defineN4 #defineM16 main() {charS[M][3]; intk,m,X,j; f0r(k=1;klt;=N;k++)//确定移动次数 {for(X=1,m=1;mlt;=k一1;m++) x=x2; S[x][0]=k; S

文档评论(0)

cai + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档