C语言--汉诺塔问题

一·介绍

假设从左到右为ABC三根柱子,汉诺塔规定让A柱上的圆盘移动到C柱,其间B柱起到辅助作用,要求小盘上不能放大盘,每次移动只能移动一个圆盘,请用递归的方法做出有n个圆盘时需要几步才能完成。

二·理清思路

1·自己动手尝试

自己草纸上把前三个想出来,观察数字是否符合某种规律。

2·尝试总结

(1)不难发现,他的步数与一共几层存在着联系。假如有n层,那么步数就是2^n -1 ,如果找到了这个规律,那么编写代码就不是问题了。

3·具体讲解如下

假如你想不到上面的结论,或者不太理解,那么请看下面的讲解:
我们可以想象,假如有n个光盘,第一步当然是把最下面的那个挪到C柱,n-1个柱子挪到b柱,然后第二次就是把B柱上n-2个柱子挪到A柱,B柱最后剩下那个挪到C柱,依次类推。如下
塔数 步骤
1 A->C
2 A->B、A->C、B->C
3 A->C、A->B、C->B、A->C、B->A、B->C、A->C
4 A->B,A->C,B->C,A->B,C->A,C->B,A->B,A->C,B->C,B->A,C->A,B->C,A->B,A->C,B->C
… …
偶 A->B
奇 A->C

三·代码实现

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值