OutgoingZY 2017-11-07 11:19 采纳率: 100%
浏览 1155
已采纳

C语言初学者汉若塔问题

#include "stdafx.h"
void hanoi(int n, char A, char B, char C)
{
if (n == 1){
printf("Move sheet %d from %c to %c\n", n, A, C);
}
else
{
hanoi(n - 1, A, C, B);
printf("Move sheet %d from %c to %c\n", n, A, C);
hanoi(n - 1, B, A, C);
}
}
int main()
{
int n;
printf("Please enter the number of the sheets:");
scanf_s("%d", &n);
hanoi(n, 'A', 'B', 'C');
return 0;
}
主要搞不清这个程序怎么运作的,尤其是hanoi函数定义以及这个函数怎么运作的,
求大佬指点

  • 写回答

2条回答 默认 最新

  • wanghy1995 2017-11-07 12:27
    关注

    你得先知道程序递归调用是怎么回事,如果不明白请翻书。
    之后再明白汉诺塔的解法,再读程序就清楚很多了。
    解决汉诺塔问题,可以抽象成三个步骤
    我们的目标是,把n个盘从A塔移到C塔
    1. 把n-1个盘从A塔移到B塔;
    2. 把第n个盘从B塔移到C塔;
    3. 把n-1个塔从B塔移到C塔。
    你会发现第1、2步完成之后,问题又回到了开头,正是我们最开始的目标,只不过n变成了n-1,目标塔的顺序改变了而已。
    这样不断地重复调用同一个函数,直到n = 1这个特殊情况,写个if打破个这连锁的循环。
    如下:
    hanoi(n,A,B,C)函数的功能就是,把n个盘从A塔移到C塔
    那么hanoi(n-1,A,C,B)的功能就是,把n-1个盘从A塔移到B塔
    .....
    后面n递减至1.
    hanoi(1,A,B,C)就是将A移至C。

    看代码:
    hanoi(n - 1, A, C, B);
    printf("Move sheet %d from %c to %c\n", n, A, C);
    hanoi(n - 1, B, A, C);
    这三行完成的事正是1、2、3这三个步骤,这很好理解。
    这是个数学问题,写出这样的程序确实不简单。
    如果不知道这个问题的解法的话,确实很难理解程序递归,如果明白解法,程序一目了然。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog