鱼C论坛

 找回密码
 立即注册
查看: 2800|回复: 4

汉诺塔理解不了

[复制链接]
发表于 2020-2-22 14:15:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
为什么当输入的数字为偶数时第一个盘子是从a移到b的,为奇数时a移向c
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-2-22 14:26:31 | 显示全部楼层
#include<stdio.h>
void main()   
{
        void hanoi(int n,char one,char two,char three);
        int m;
        printf("intput the number of diskes:");
        scanf("%d",&m);
        printf("The step to moveing %d diskes:\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);
}

这个问题的程序
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-22 14:31:24 | 显示全部楼层
首先你的思考方向就是错的。
你要理解的是什么叫递归,而不是一来就搞个汉诺塔,为什么要这样移又为什么要那样移;翅膀没硬就想飞的道理。
递归简单的示例很多,要想理解递归搞个最简单的示例,走下流程,一切自然而解,然后再来走走汉诺塔的流程,盘子设在最少。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-2-23 13:01:47 | 显示全部楼层
谢谢关心,本问题已找到问题根源解决了,祝你身体健康,万事如意!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-2-23 13:02:20 | 显示全部楼层
ba21 发表于 2020-2-22 14:31
首先你的思考方向就是错的。
你要理解的是什么叫递归,而不是一来就搞个汉诺塔,为什么要这样移又为什么要 ...

谢谢关心,本问题已找到问题根源解决了,祝你身体健康,万事如意
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-2 19:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表