鱼C论坛

 找回密码
 立即注册
查看: 1771|回复: 1

一个关于递归算法的问题 想了很久..

[复制链接]
发表于 2014-6-29 14:31:25 | 显示全部楼层 |阅读模式
4鱼币
一个国王因为听信谗言将一个无辜的数学家关进了监狱。虽然事后发现确属冤枉,但碍于面子,国王不肯认错。为了挽回,于是国王决定用Bytish锁链将其锁在墙上。这种锁链由n(10≤n≤1000)个固定在墙上的铁环和铁棒组成。由于环不是都套在棒上,要想把整副锁链取下是十分困难的。数学家必须自己通过不断取下和套上铁环最终将所有铁环都取下才能获得自由。取下或套上铁环的规则是:
Ø  铁环从1、2、……、n依次编号。
Ø  一次只能把一个环取下或套上。
Ø  编号为1的环无论何时都能取下或套上。
Ø  如果编号为1、……、k-1(1≤k≤n)的环已经从棒上取下,并且k环套在棒上,则可以取下或套上编号为k+1环。
程序要求按照从n、n-1、n-2、……、1的顺序,将移除掉n号环的全部过程作为一个段落输出,然后将移除n-1号环的全部过程也作为一个段落输出,其余依此类推。
题目就是这样。
应该是用递归的方法
    解开有n个环的锁链的过程:
当n=1时,解1
当n=2时,解2 解1

当n=3时,解1 解3 套1 解2 解1
当n=4时,解2 解1 解4 套1 套2 解1 解3 套1 解2 解1
....
题目要求分别输出移除第n号环的过程...移除第n号环的过程是先移除前n-2个环,然后移除第n号环。这个用递归的方法我怎么都想不明白,如果要让移除每个环的过程都相似的话,在移除了第n号环之后是不是还应该把前n-2个环再套上,让锁链恢复到由n-1个环构成的状态,这样才能递归?还有怎么输出结果呢,n的取值很大,最后输出的结果感觉很复杂..
求助!最好能把程序大致编出来让我看一看..指出一下我思路的问题..

额 发过一次帖子了 当时忘了悬赏 重开一个吧...求助!!

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-8-6 10:49:26 | 显示全部楼层
:big
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-26 05:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表