版权声明:本文为博主原创文章,若有错误之处望大家批评指正!转载需附上原文链接,谢谢! https://blog.csdn.net/summer_dew/article/details/83922566
#include<stdio.h>
//将n个盘子从x借助y移动到z
void move(int n,char x,char y,char z) {
if (1==n)
printf("%c-->%c\n",x,z);
else {
move(n-1,x,z,y); //将n-1个盘子从x借助z移动到y
printf("%c-->%c\n",x,z);
move(n-1,y,x,z);
}
}
int main() {
int n;
printf("请输入汉诺塔的层数:");
scanf("%d",&n);
printf("移动的步骤如下:\n");
move(n,'X','Y','Z');
return 0;
}