汉诺塔游戏

None.gif #include  < stdio.h >
None.gif#include 
< conio.h >
None.gif
void  hanoi( int , int , int , int );
None.gif
void  main()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif 
int n;
InBlock.gif clrscr();
InBlock.gif printf(
"Input n:");
InBlock.gif scanf(
"%d",&n);
InBlock.gif hanoi(n,
1,2,3);
ExpandedBlockEnd.gif}

None.gif
None.gif
void  hanoi( int  n, int  a, int  b, int  c)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif 
if (n==1)
ExpandedSubBlockStart.gifContractedSubBlock.gif   printf(
"%d-%d",a,c);       /**//* n=1时,直接将金片从a移动到c */
InBlock.gif 
else
ExpandedSubBlockStart.gifContractedSubBlock.gif 
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif   hanoi(n
-1,a,c,b);           /**//* n-1个金片从a经过c移动到b */
ExpandedSubBlockStart.gifContractedSubBlock.gif   printf(
"  %d-%d  ",a,c);       /**//* 将第n个金片从a移动到c */
ExpandedSubBlockStart.gifContractedSubBlock.gif   hanoi(n
-1,b,a,c);           /**//* 将n-1个金片从b经过a移动到c */
ExpandedSubBlockEnd.gif }

ExpandedBlockEnd.gif}

转载于:https://www.cnblogs.com/qixin622/archive/2007/01/14/620051.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值