code.club

 找回密碼
 立即註冊
搜索
查看: 11304|回復: 2
打印 上一主題 下一主題

河內塔的程式

[複製鏈接]
跳轉到指定樓層
樓主
發表於 2015-8-13 11:28:54 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
本帖最後由 enter 於 2015-8-13 11:33 編輯

太強了,還沒想通,先留著作記錄。這裡有比較詳細的說明,http://finalfrank.pixnet.net/blo ... -%E9%81%9E%E8%BF%B4

#include <stdio.h>
void hanoi(int,int,int,int);

int main(void)
{
  int i;

  printf("總共有多少圓盤要搬?\n");
  scanf("%d",&i);
  hanoi(i,1,2,3);

  return 0;
}

void hanoi(int i,int begin,int mid,int last)
{
  if (i==1) /* 遞迴終止條件 */
    printf("將第 %d 個盤子從第 %d 個塔移到第 %d 個塔\n",
     i,begin,last);
  else
  {
    hanoi(i-1,begin,last,mid);
    printf("將第 %d 個盤子從第 %d 個塔移到第 %d 個塔\n", i,begin,last);
    hanoi(i-1,mid,begin,last);
  }
}
回復

使用道具 舉報

沙發
 樓主| 發表於 2015-8-13 14:30:52 | 只看該作者
本帖最後由 enter 於 2015-8-13 14:36 編輯

河內塔次數的算法。

#include <stdio.h>
#include <stdlib.h>
int hanoistep(int);
int main(void){
        int x;
       
        printf("enter how many plates?\n");
        scanf("%d",&x);
       
        printf("Need %d steps to complete.\n",hanoistep(x));
       
        return 0;
}

int hanoistep(int i){
       
        if(i==1) return 1;
        else
        return 2*hanoistep(i-1)+1;
}

回復 支持 反對

使用道具 舉報

板凳
 樓主| 發表於 2015-8-13 14:56:11 | 只看該作者
本帖最後由 enter 於 2015-8-13 14:57 編輯

講解很清楚。




回復 支持 反對

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即註冊

本版積分規則

小黑屋|手機版|Archiver|code.club  

GMT+8, 2024-11-21 22:42 , Processed in 0.095779 second(s), 17 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回復 返回頂部 返回列表