最近在複習c,然後辛辛苦苦打出的**,不捨得練習完就刪了,就copy到這來了,做個紀念
#include
#include //用到exit;
#define n 6 //轉移的圓盤個數
int pegs[3][n]=;//二維陣列儲存柱子及對應圓盤
int p_num[3]=;//儲存柱子的圓盤個數
int k=0;
//n:移動的圓盤個數,from和to:從哪移到哪,using:中介
void move(int n,int from,int to,int use);
//出棧,peg:柱子序號
int pop(int peg);
//進棧,peg:柱子序號
void push(int peg,int a);
//列印實時動作
void print_action();
int main()
/*a、b、c三個柱子,從a到c
遞迴思想:移動n個到c,則需移動n-1個到b,再把a剩下的那乙個移動到c,然後再將b的n-1個移動到c;
移動n-1個到b,則需要移動n-2個到c,再把a最上面乙個移動到b,然後再將c的n-2個移動到b;
其他同理。
*/void move(int n,int from,int to,int use)}/*
出棧*/
int pop(int peg)else}/*
入棧*/
void push(int peg,int a)else
/*列印實時動作
*/void print_action()
printf("\t");
}
python 漢諾塔 Python漢諾塔
import turtle class stack def init self self.items def isempty self return len self.items 0 def push self,item def pop self return self.items.pop def ...
漢諾塔合集之漢諾塔3
漢諾塔3 步驟分析 1.當只有乙個圓盤時,要從a到b再到c 2.同樣擴充套件經典漢諾塔問題來看,先把a柱上 n 1 個圓盤,經b移動到c 3.把最後乙個圓盤從a移動到b 4.把c柱上的 n 1 個圓盤,經b移動 移回 到a 5.把b上的最後乙個圓盤從b移到c 6.最後把a上的 n 1 個圓盤經過b移...
漢諾塔問題
問題 假設有3個分別命名為x,y,z的寶塔,在塔座x上插有n個直徑大小各不相同,從小到大編號為1,2,3。n的圓盤。現要求將x軸上的n個圓盤移至塔座z上 並仍然按同樣的順序疊排,圓盤移動時必須遵循下列規則 1.每次只能移動乙個圓盤 2.圓盤可以插在x,y和z中的任一塔座上 3.任何時刻都不能將乙個較...