| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付学习型 ASP/PHP/ASP.NET 主机 30元/年
高端软件开发 = 年薪十万不是梦赛孚耐:软件保护加密专家身份认证令牌USB KEY 
共有 440 人关注过本帖
标题:初学求c语言中汉诺塔的递归解法,请赐教,谢谢
收藏  订阅  推荐  打印 
qaz2wsx
Rank: 1
等级:新手上路
帖子:6
积分:160
注册:2007-4-11
初学求c语言中汉诺塔的递归解法,请赐教,谢谢

只有3跟柱子,第一跟上3个盘,
求用递归的算法
请赐教谢谢了
希望能把详细的思路,写上,不胜感激
搜索更多相关主题的帖子: 汉诺塔  c语言  解法  递归  
2007-4-20 18:53
海蓝啸
Rank: 12Rank: 12Rank: 12
来自:安徽
等级:贵宾
威望:17
帖子:1606
积分:16753
注册:2006-4-3

老谭书写的不知道有多详细

这个社会太复杂。。。
2007-4-20 19:19
qaz2wsx
Rank: 1
等级:新手上路
帖子:6
积分:160
注册:2007-4-11

谢谢了
我没看那本书,
我看的是迪泰儿父子合做的c程序设计教程
还是请大家帮忙解答一下

2007-4-20 22:43
qaz2wsx
Rank: 1
等级:新手上路
帖子:6
积分:160
注册:2007-4-11

我找了本谭sir的书看了,还不太明白
就是递归后,每一级是怎么返回的呢 ?
整个逻辑好象明白,又好象不明白,很模糊的感觉
假设是4个盘
move(int n,int x,int y,int z)
{
if(n==1)
printf("%c-->%c\n",x,z);
else
{
move(n-1,x,z,y);/*就是先把3个盘移到y上接着就是move(n-2,x,z,y)吗?直到只有一个盘,然后返回的过程不太明白*/
printf("%c-->%c\n",x,z);
move(n-1,y,x,z);
}
}
main()
{
int h;
printf("\ninput number:\n");
scanf("%d",&h);
printf("the step to moving %2d diskes:\n",h);
move(h,'a','b','c');
2007-4-21 02:03
海蓝啸
Rank: 12Rank: 12Rank: 12
来自:安徽
等级:贵宾
威望:17
帖子:1606
积分:16753
注册:2006-4-3

没有返回什么。。。。就是一层层递归下去。。。每一层的程序都没有执行完。。。一直深入到最里面一层。。。。最里面一层是最先执行完的,然后再逐层往外,不知道我这样说你能不能理解。。。LZ可以先看看递归原理,理解以后再看这题就会很明白了。。。。
其实递归不太好理解的。。。我当初也花了很长时间才算彻底理解了

[此贴子已经被作者于2007-4-21 9:29:45编辑过]


这个社会太复杂。。。
2007-4-21 09:28
qaz2wsx
Rank: 1
等级:新手上路
帖子:6
积分:160
注册:2007-4-11

还是不太明白,
我自己在漫漫看书
非常感谢你,呵呵
2007-4-21 13:13
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.090121 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved