C語言用遞歸函數(shù)實(shí)現(xiàn)漢諾塔
漢諾塔(Hanoi)是什么?


一個簡單的漢諾塔就如上圖所示,有三個放置點(diǎn),放置物必須遵循上小下大的規(guī)則,依次將1中的放置物全部放置到3中。就比如該圖中有4個放置物,若將A上的放置物全部移至C上,具體的步驟是:A->B A->C B->C A->B C->A C->B A->B A->C B->C B->A C->A B->C A->B A->C B->C。
那么,C語言如何實(shí)現(xiàn)漢諾塔呢?
第一步要先確定起始位置、中轉(zhuǎn)位置、目的位置,在一開始A是起始位置,B是中轉(zhuǎn)位置,C是目的位置,在后續(xù)移動物塊的時(shí)候會一直改變這三個位置的功能,以達(dá)到最終目標(biāo)。
漢諾塔的基本思路是:
第一階段:將n-1個物塊(也就是除最底部的物塊外)經(jīng)過一系列地堆放(這里就可以使用到遞歸的方法來實(shí)現(xiàn)),最后放置到中轉(zhuǎn)位置上,然后把起始位置剩下的物塊放到目的位置上,如下圖:


以上一系列地堆放是指:以A為起始位置,C為中轉(zhuǎn)位置,B為目的位置,也就相當(dāng)于把C看作是一個中間存放點(diǎn),來幫助這n-1個物塊放到B里面去。
第二階段:然后會發(fā)現(xiàn),變化后的漢諾塔的形式也和之前是差不多的,如果把B看作是起始位置,A是中轉(zhuǎn)位置,C是目的位置。就可以一直按照上面的那個方法一直遞歸下去,如下圖:


以此類推……最后就能實(shí)現(xiàn)把所有的物塊全部從A搬到C。
具體代碼見下(注意點(diǎn)在代碼下面):
//C語言實(shí)現(xiàn)漢諾塔
#include <stdio.h>
void move(char p1, char p2)
{
printf("%c->%c ", p1, p2);
}
//n:個數(shù) pos1:起始位置 pos2:中轉(zhuǎn)位置 pos3:目的位置
void Hanoi(int n, char pos1, char pos2, char pos3)
{
if (n == 1)
{
move(pos1, pos3);
}
else
{
Hanoi(n - 1, pos1, pos3, pos2);
move(pos1, pos3);
Hanoi(n - 1, pos2, pos1, pos3);
}
}
int main()
{
Hanoi(1, 'A', 'B', 'C');
printf("\n");
Hanoi(2, 'A', 'B', 'C');
printf("\n");
Hanoi(3, 'A', 'B', 'C');
printf("\n");
Hanoi(4, 'A', 'B', 'C');
printf("\n");
return 0;
}注意點(diǎn)一:代碼中的n值不能太大,因?yàn)橐苿哟螖?shù)是隨n的增大呈指數(shù)倍增長。
注意點(diǎn)二:n為1的時(shí)候已近到達(dá)最小單位(也就是最底層),不需要使用遞歸;n為大于1的值時(shí),需要遞歸到1才能進(jìn)行。
注意點(diǎn)三:第一階段使用遞歸表示的是把上面n-1層全部移到B中;而第二階段使用遞歸表示的是把B中全部移到C中。
總結(jié)
這樣就可以簡單地完成漢諾塔,此代碼并不是最優(yōu)方法,但是理解起來比較容易。遞歸在實(shí)際中運(yùn)用的不是很多,但是也要看得懂代碼和寫出類似這種漢諾塔等遞歸函數(shù)的基礎(chǔ)代碼。
到此這篇關(guān)于C語言用遞歸函數(shù)實(shí)現(xiàn)漢諾塔的文章就介紹到這了,更多相關(guān)C語言漢諾塔內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++中4種強(qiáng)制類型轉(zhuǎn)換的區(qū)別詳析
這篇文章主要給大家介紹了關(guān)于C++中4種強(qiáng)制類型轉(zhuǎn)換區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
在Visual Studio Code中使用CSSComb格式化CSS文件的教程
這篇文章主要介紹了在Visual Studio Code中使用CSSComb格式化CSS文件,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03
c++網(wǎng)絡(luò)編程下Linux的epoll技術(shù)和Windows下的IOCP模型
c++ 網(wǎng)絡(luò)編程LINUX-epoll/windows-IOCP下socket opoll函數(shù)用法 優(yōu)于select方法的epoll 以及windows下IOCP 解決多進(jìn)程服務(wù)端創(chuàng)建進(jìn)程資源浪費(fèi)問題,感興趣的小伙伴一起來學(xué)習(xí)吧2021-08-08
opencv實(shí)現(xiàn)圖像顏色空間轉(zhuǎn)換
這篇文章主要為大家詳細(xì)介紹了opencv實(shí)現(xiàn)圖像顏色空間轉(zhuǎn)換,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08
C語言實(shí)現(xiàn)的循環(huán)單鏈表功能示例
這篇文章主要介紹了C語言實(shí)現(xiàn)的循環(huán)單鏈表功能,結(jié)合實(shí)例形式分析了基于C語言實(shí)現(xiàn)的循環(huán)單鏈表定義、創(chuàng)建、添加、刪除、打印、排序等相關(guān)操作技巧,需要的朋友可以參考下2018-04-04

