- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
                您可能关注的文档
最近下载
- 电力分析软件:PSSE二次开发all.docx VIP
- 冠脉介入培训试题及答案.docx VIP
- 电力调度软件:PSSE二次开发all.docx VIP
- 电力分析软件:PSSE二次开发_(4).PSSE编程环境与语言.docx VIP
- 电力调度软件:PSSE二次开发_(6).PSSE高级功能与优化.docx VIP
- 电力调度软件:PSSE二次开发_(3).Python在PSSE中的应用.docx VIP
- 电力分析软件:PSSE二次开发_(24).未来电力系统趋势与PSSE的发展.docx VIP
- 既有管线保护专项施工方案(已审批).doc
- 不同人群的运动处方.pptx VIP
- 电力调度软件:PSSE二次开发_(5).PSSE案例分析与实践.docx VIP
 原创力文档
原创力文档 
                        

文档评论(0)