日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

經(jīng)典遞歸解決漢諾塔!

 計(jì)科圖書(shū) 2014-09-15

算法:當(dāng)只有一個(gè)盤(pán)子的時(shí)候,只需要從將A塔上的一個(gè)盤(pán)子移到C塔上。

            當(dāng)A塔上有兩個(gè)盤(pán)子是,先將A塔上的1號(hào)盤(pán)子(編號(hào)從上到下)移動(dòng)到B塔上,再將A塔上的2號(hào)盤(pán)子移動(dòng)的C塔上,最后將B塔上的小盤(pán)子移動(dòng)到C塔上。

            當(dāng)A塔上有3個(gè)盤(pán)子時(shí),先將A塔上編號(hào)1至2的盤(pán)子(共2個(gè))移動(dòng)到B塔上(需借助C塔),然后將A塔上的3號(hào)最大的盤(pán)子移動(dòng)到C塔,最后將B塔上的兩個(gè)盤(pán)子借助A塔移動(dòng)到C塔上。

           當(dāng)A塔上有n個(gè)盤(pán)子是,先將A塔上編號(hào)1至n-1的盤(pán)子(共n-1個(gè))移動(dòng)到B塔上(借助C塔),然后將A塔上最大的n號(hào)盤(pán)子移動(dòng)到C塔上,最后將B塔上的n-1個(gè)盤(pán)子借助A塔移動(dòng)到C塔上。

          綜上所述,除了只有一個(gè)盤(pán)子時(shí)不需要借助其他塔外,其余情況均一樣(只是事件的復(fù)雜程度不一樣)。

         

  1. #include   
  2. //第一個(gè)塔為初始塔,中間的塔為借用塔,最后一個(gè)塔為目標(biāo)塔  
  3. int i=1;//記錄步數(shù)  
  4. void move(int n,char from,char to) //將編號(hào)為n的盤(pán)子由from移動(dòng)到to  
  5. {printf("第%d步:將%d號(hào)盤(pán)子%c---->%c\n",i++,n,from,to);  
  6. }  
  7. void hanoi(int n,char from,char denpend_on,char to)//將n個(gè)盤(pán)子由初始塔移動(dòng)到目標(biāo)塔(利用借用塔)  
  8. {  
  9.     if (n==1)  
  10.     move(1,from,to);//只有一個(gè)盤(pán)子是直接將初塔上的盤(pán)子移動(dòng)到目的地  
  11.     else  
  12.     {  
  13.       hanoi(n-1,from,to,denpend_on);//先將初始塔的前n-1個(gè)盤(pán)子借助目的塔移動(dòng)到借用塔上  
  14.       move(n,from,to);              //將剩下的一個(gè)盤(pán)子移動(dòng)到目的塔上  
  15.       hanoi(n-1,denpend_on,from,to);//最后將借用塔上的n-1個(gè)盤(pán)子移動(dòng)到目的塔上  
  16.     }  
  17. }  
  18. void main()  
  19. {  
  20.      printf("請(qǐng)輸入盤(pán)子的個(gè)數(shù):\n");  
  21.      int n;  
  22.      scanf("%d",&n);  
  23.      char x='A',y='B',z='C';  
  24.      printf("盤(pán)子移動(dòng)情況如下:\n");  
  25.      hanoi(n,x,y,z);  
  26. }  

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶(hù)發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶(hù) 評(píng)論公約

    類(lèi)似文章 更多