漢諾塔(Tower of Hanoi)c語言實現

2021-10-05 13:43:09 字數 853 閱讀 3188

最近在複習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.任何時刻都不能將乙個較...