当前位置: 代码迷 >> C语言 >> 有一个关于汗诺塔打印输出“运行结果”的问题请教大家?
  详细解决方案

有一个关于汗诺塔打印输出“运行结果”的问题请教大家?

热度:169   发布时间:2008-04-21 17:04:46.0
有一个关于汗诺塔打印输出“运行结果”的问题请教大家?
程序代码如下:
//A塔上有m个盘子,从上到下依次增大,将A塔上的盘子移到C塔上,一次只能移动一个,而且也要保证C塔上的盘子从上到下依次增大,可以用B过度。
#include <stdio.h>  
void move(char x,char y)
{    
    printf("%c-->%c ",x,y);    
}
void hanoi(int n,char one,char two,char three)
{
    if(n==1) move(one,three);
    else
    {
        hanoi(n-1,one,three,two);
        move(one,three);
        hanoi(n-1,two,one,three);
    }
}
int main(void)
{
    int m;           //m是塔上的盘子数
    clrscr();
    printf("Input the number of disks:");
    scanf("%d",&m);
    printf("The step to moving %d disks:\n",m);
    hanoi(m,'A','B','C');  //A,B,C分别代表三个塔
    getch();
    return 0;
}
问题是打印的结果不规则,我想让打印结果有规律的换行,该如何解决?
请大家运行一下指点指点。程序是用递归调用编的。
搜索更多相关的解决方案: 运行结果  诺塔  打印  输出  

----------------解决方案--------------------------------------------------------
这个是程序员教程上的例题....用递归,你自己画画图吧...画图就可以清楚了...
----------------解决方案--------------------------------------------------------
每次动作后加个换行,想一想加在哪里
----------------解决方案--------------------------------------------------------
2楼我说的是打印结果,我想让打印结果有规律。本程序中move函数并未真正移动盘子,而只是打印出移盘的方案。(从哪一个塔移到哪一个塔),我想是在这加,可是不知怎么加啊?打印的结果都是A-->B或B-->C不是单个的字符。
----------------解决方案--------------------------------------------------------