|
编程中国
|
业界新闻
|
技术文章
|
视频教程
|
下载频道
|
程序源码
|
个人空间
|
编程论坛
|
登录
注册
平板模式
论坛地图
帮助
编程论坛
→
开发语言
→
C语言论坛
→ 初学求c语言中汉诺塔的递归解法,请赐教,谢谢
我的收件箱(0)
全能ASP/PHP/ASP.NET主机,支持月付
专业
MSSQL
数据库空间,支持月付
专业
MySQL
数据库空间,支持月付
学习型 ASP/PHP/ASP.NET 主机
30
元/年
高端软件开发 = 年薪十万不是梦
赛孚耐:软件保护加密专家
身份认证令牌USB KEY
共有
440
人关注过本帖
标题:初学求c语言中汉诺塔的递归解法,请赐教,谢谢
waiting……
收藏
订阅
推荐
打印
qaz2wsx
等级:新手上路
帖子:6
积分:160
注册:2007-4-11
楼主
初学求c语言中汉诺塔的递归解法,请赐教,谢谢
只有3跟柱子,第一跟上3个盘,
求用递归的算法
请赐教谢谢了
希望能把详细的思路,写上,不胜感激
搜索更多相关主题的帖子:
汉诺塔
c语言
解法
递归
2007-4-20 18:53
海蓝啸
来自:安徽
等级:贵宾
威望:
17
帖子:1606
积分:16753
注册:2006-4-3
第
2
楼
老谭书写的不知道有多详细
这个社会太复杂。。。
2007-4-20 19:19
qaz2wsx
等级:新手上路
帖子:6
积分:160
注册:2007-4-11
第
3
楼
谢谢了
我没看那本书,
我看的是迪泰儿父子合做的c程序设计教程
还是请大家帮忙解答一下
2007-4-20 22:43
qaz2wsx
等级:新手上路
帖子:6
积分:160
注册:2007-4-11
第
4
楼
我找了本谭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
海蓝啸
来自:安徽
等级:贵宾
威望:
17
帖子:1606
积分:16753
注册:2006-4-3
第
5
楼
没有返回什么。。。。就是一层层递归下去。。。每一层的程序都没有执行完。。。一直深入到最里面一层。。。。最里面一层是最先执行完的,然后再逐层往外,不知道我这样说你能不能理解。。。LZ可以先看看递归原理,理解以后再看这题就会很明白了。。。。
其实递归不太好理解的。。。我当初也花了很长时间才算彻底理解了
[此贴子已经被作者于2007-4-21 9:29:45编辑过]
这个社会太复杂。。。
2007-4-21 09:28
qaz2wsx
等级:新手上路
帖子:6
积分:160
注册:2007-4-11
第
6
楼
还是不太明白,
我自己在漫漫看书
非常感谢你
,呵呵
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