递归实现Hanoi塔

#include <iostream>
int hanoi(char a, char b, char c, int n, int time);

int main()
{

    int  n;
    printf("Input the number of diskes:");
    scanf_s("%d", &n);
    int time = 0;
    time = hanoi('A', 'B', 'C', n, time);
    printf("\n移动次数:time = %d", time);
}


//Hanoi塔(汉诺塔):a,b,c表示三根柱子,n表示有几个圆盘,time表示移动的次数
//将a柱子上的盘子借助b柱子移动到c柱子
int hanoi(char a, char b, char c, int n, int time)         
{
    if (1 == n)                                          
    {
        //如果是一个盘子直接将a柱子上的盘子移动到c
        printf("%c-->%c\n", a, c);
        time++;
        return time;
    }
    else
    {
        //将a柱子上n-1个盘子借助c柱子,移动到b柱子
        time =  hanoi(a, c, b, n - 1, time);
        //再直接将a柱子上的最后一个盘子移动到c
        printf("%c-->%c\n", a, c);
        time++;
        //然后将b柱子上的n-1个盘子借助a移动到c
        time = hanoi(b, a, c, n - 1, time);
    }
}

参考链接:汉诺塔递归算法详细解析(C语言版) - 命运丶peng - 博客园

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

路漫漫之编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值