[递归] 汉诺塔 - C语言

版权声明:本文为博主原创文章,若有错误之处望大家批评指正!转载需附上原文链接,谢谢! 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;
}

猜你喜欢

转载自blog.csdn.net/summer_dew/article/details/83922566