【c】汉诺塔递归

汉诺塔问题的递归解决方案

从左到右有A、B、C三根柱子,其中A柱子上 面有从小叠到大的n个圆盘,现要求将A柱子上的圆盘移到 C柱子上去,期间只有一个原则:一次只能移到一个盘子且 大盘子不能在小盘子上面,求移动的步骤

#include <stdio.h>

int HanNuoTa(int n, char Src, char Dst, char Tmp)
{
	if (1 == n)
	{
		printf("%c -> %c\n", Src, Dst);
	}
	else
	{
		HanNuoTa(n-1, Src, Tmp, Dst);
		printf("%c -> %c\n", Src, Dst);
		HanNuoTa(n-1, Tmp, Dst, Src);
	}

	return 0;
}

int main(int argc, const char *argv[])
{
	int n = 0;

	printf("请输入盘子的个数:\n");
	scanf("%d", &n);

	HanNuoTa(n, 'A', 'C', 'B');

	return 0;
}

复制代码

转载于:https://juejin.im/post/5b4b18096fb9a04fa8671e9a

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值