| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1867 人关注过本帖, 1 人收藏
标题:帮忙解释下汉诺塔问题
只看楼主 加入收藏
悠闲的紫
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2008-10-13
收藏(1)
 问题点数:0 回复次数:6 
帮忙解释下汉诺塔问题
void move(int n,int x,int y,int z)
{
    if(n==1)
      printf("\t\t\t%c-->%c\n",x,z);
    else
    {
      move(n-1,x,z,y);
      printf("\t\t\t%c-->%c\n",x,z);
      move(n-1,y,x,z);
    }
}

这个是程序,我不知道为什么要这样写谁能帮忙解释下下!~~~
先谢过
搜索更多相关主题的帖子: 汉诺塔 解释 
2008-10-14 09:51
悠闲的紫
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2008-10-13
收藏
得分:0 
我刚刚接触C,这个是书上的,
虽然没图形输出,但能显示搬运的步骤。
我不知道是怎么推出来的,谁能帮演示下。

把知识都和我说
2008-10-15 16:39
faminxmu
Rank: 3Rank: 3
来 自:厦门
等 级:论坛游侠
帖 子:191
专家分:106
注 册:2008-4-23
收藏
得分:0 
自己慢慢研究,
#include<stdio.h>//this is the program of hannoih
void main()
{
     void hanoi(int n,char one,char two,char three);
     int m;
     printf("输入数目n=");
     scanf("%d",&m);
     printf("移动步骤是:\n");
     hanoi(m,'A','B','C');
     }
     void hanoi(int n,char one,char two,char three)
     {
          void move(char x,char y);
          if(n==1) move(one,three);
          else
          {
              hanoi(n-1,one,three,two);
              move(one,three);
              hanoi(n-1,two,one,three);
              }
              }
              void move(char x,char y)
              {
                   printf("把%c的第一个=>%c\n",x,y);
                   }

在虚拟的世界中寻找目标。
2008-10-15 16:46
q7q8q7
Rank: 1
来 自:河工大
等 级:新手上路
帖 子:16
专家分:0
注 册:2008-9-30
收藏
得分:0 
就是递归啊,规律都一样的,3个一体,书上网上讲解都很详细,不用列下来了吧?
2008-10-15 17:22
悠闲的紫
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2008-10-13
收藏
得分:0 
3楼大大谢谢

把知识都和我说
2008-10-16 16:51
xinshou2008
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2008-10-16
收藏
得分:0 
利用了递归的思想。如果只有一个盘子的话,就直接把盘子按a-b-c的顺序就可以啦。如果有两个盘子的话就要借助b啦。先把盘子按a-c-b,即把最小的盘子先放在b上。然后在把盘子按b-a-c的顺序放就可以啦!实在不明白的话,就动手做一个小实验就明白啦。我以前就是这么做的。老师讲了很多遍怎么都不明白!
2008-10-16 21:03
悠闲的紫
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2008-10-13
收藏
得分:0 
有 a b c 三个柱子
                        
判断 盘子个数(n)   为1  a上的盘子 -> c

否则:
执行 move n-1 a c b     .....就是说现在   这里 a=a c=b b=c
              
判断 盘子个数(n-1)  为1  a上的盘子 -> c   就是把 a->b

执行 move n-1 b a c     ..........现在    这里 b=a=a a=c=b c=b=c

判断 盘子个数(n)   为1  a上的盘子 -> c    就是把 b->c


也就是里边的柱子的位置在变是不是啊?

把知识都和我说
2008-10-20 09:59
快速回复:帮忙解释下汉诺塔问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016946 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved