本文實例講述了PHP遞歸實現(xiàn)漢諾塔問題的方法。分享給大家供大家參考,具體如下:
漢諾塔(又稱河內(nèi)塔)問題是源于印度一個古老傳說的益智玩具。大梵天創(chuàng)造世界的時候做了三根金剛石柱子,在一根柱子上從下往上按照大小順序摞著64片黃金圓盤。大梵天命令婆羅門把圓盤從下面開始按大小順序重新擺放在另一根柱子上。并且規(guī)定,在小圓盤上不能放大圓盤,在三根柱子之間一次只能移動一個圓盤。簡而言之,有三根相鄰的柱子,標號為A,B,C,A柱子上從下到上按金字塔狀疊放著n個不同大小的圓盤,要把所有盤子一個一個移動到柱子B上,并且每次移動同一根柱子上都不能出現(xiàn)大盤子在小盤子上方,請問至少需要多少次移動?
遞歸過程序如下:
1)把n-1個圓從A移到C
2)把剩下一個由A移到B
3)再把n-1個由C移到B,完成
代碼如下:
?php
//將所有圓盤從a移到b
function hanuota($n,$a,$b,$c){
global $step;
if($n==1){
$step++;
echo "將圓盤 $n 從 $a 柱子 到 $b 柱子 br />";
}else{
hanuota($n-1,$a,$c,$b);
$step++;
echo "將圓盤 $n 從 $a 柱子 到 $b 柱子 br />";
hanuota($n-1,$c,$b,$a);
}
}
//移動的次數(shù)
$step = 0;
hanuota(4, 'A', 'B', 'C');
echo "移動次數(shù):" . $step;
?>
運行結(jié)果:
將圓盤 1 從 A 柱子 到 C 柱子
將圓盤 2 從 A 柱子 到 B 柱子
將圓盤 1 從 C 柱子 到 B 柱子
將圓盤 3 從 A 柱子 到 C 柱子
將圓盤 1 從 B 柱子 到 A 柱子
將圓盤 2 從 B 柱子 到 C 柱子
將圓盤 1 從 A 柱子 到 C 柱子
將圓盤 4 從 A 柱子 到 B 柱子
將圓盤 1 從 C 柱子 到 B 柱子
將圓盤 2 從 C 柱子 到 A 柱子
將圓盤 1 從 B 柱子 到 A 柱子
將圓盤 3 從 C 柱子 到 B 柱子
將圓盤 1 從 A 柱子 到 C 柱子
將圓盤 2 從 A 柱子 到 B 柱子
將圓盤 1 從 C 柱子 到 B 柱子
移動次數(shù):15
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設計算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學運算技巧總結(jié)》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- php實現(xiàn)猴子選大王問題算法實例
- PHP貪婪算法解決0-1背包問題實例分析
- php約瑟夫問題解決關(guān)于處死犯人的算法
- PHP基于回溯算法解決n皇后問題的方法示例
- PHP使用棧解決約瑟夫環(huán)問題算法示例
- PHP基于遞歸算法解決兔子生兔子問題
- PHP經(jīng)典算法集錦【經(jīng)典收藏】
- PHP常用算法和數(shù)據(jù)結(jié)構(gòu)示例(必看篇)
- php經(jīng)典算法集錦
- PHP實現(xiàn)的解漢諾塔問題算法示例