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 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘