汉诺塔(代码记录+注释)

Posted 0526yao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了汉诺塔(代码记录+注释)相关的知识,希望对你有一定的参考价值。

//汉诺塔问题 
//输出移动的步骤 
#include <stdio.h>
//记录步数 
int i = 1; 
//n 第几号盘移动, from 移动塔  to 目标塔 
void move(int n, char from,char to){
    printf("第%d次移动第%d号盘: %c----->%c
",i++,n,from,to); 
} 

void hanoi(int n,char from,char mid,char to){
    if(n==1){
        move(n,from,to);//只有一个盘子是直接将初塔上的盘子移动到目的地
    }else{
        hanoi(n-1,from, to, mid);//先将初始塔的前n-1个盘子借助目的塔移动到借用塔上
        move(n,from,to);        //将剩下的一个盘子移动到目的塔上
        hanoi(n-1,mid, from,to);//最后将借用塔上的n-1个盘子移动到目的塔上
    }
}

int main(){
    printf("请输入盘子的个数:
");
    int n;
    scanf("%d",&n);
    char x=A,y=B,z=C;
    printf("盘子移动情况如下:
");
    hanoi(n,x,y,z);
    return 0 ; 
} 

技术图片

以上是关于汉诺塔(代码记录+注释)的主要内容,如果未能解决你的问题,请参考以下文章

汉诺塔的C语言代码怎么写啊

代写Haskell程序 汉诺塔汉诺塔编程代码代写

汉诺塔的递归算法

java实现汉诺塔游戏(递归)(附超详细易懂注释)

python汉诺塔非递归

python3汉诺塔简单实现代码