继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

递归-汉诺塔

慕姐8265434
关注TA
已关注
手记 1309
粉丝 222
获赞 1065

问题描述

webp

算法复杂度

  • 2的n次方再减1
    n为盘子的个数

算法实现

#include <stdio.h>#include <stdlib.h>/**
    汉诺塔问题
*/void hanoi(int n,char A, char B, char C){    if(1==n) //如果是一个盘子,直接将盘子从A柱子移到B柱子上
        printf("将编号为%d的盘子从柱子%c移到柱子%c\n",n,A,C);    else{
        hanoi(n-1,A,C,B); //将A上的n-1个盘子借助C移到B
        printf("将编号为%d的盘子从柱子%c移到柱子%c\n",n,A,C); //直接将A柱子上的第N个盘子移到C柱子上
        hanoi(n-1,B,A,C); //将B柱子上的n-1个盘子借助A移到C
    }
}int main(){    //模拟三个柱子
    char chA='A';    char chB='B';    char chC='C';    //盘子个数
    int n;    printf("请输入需要移动盘子的个数:");    scanf("%d",&n);
    hanoi(n,chA,chB,chC);    return 0;
}

运行结果

3个盘子

webp

2个盘子

webp

1个盘子

webp

5个盘子

webp



作者:桓宇Harry
链接:https://www.jianshu.com/p/db4d6d4d6c57


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP