欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言用遞歸函數(shù)實現(xiàn)漢諾塔

 更新時間:2022年01月23日 15:06:16   作者:蔡欣致  
大家好,本篇文章主要講的是C語言用遞歸函數(shù)實現(xiàn)漢諾塔,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下

漢諾塔(Hanoi)是什么?

一個簡單的漢諾塔就如上圖所示,有三個放置點,放置物必須遵循上小下大的規(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語言如何實現(xiàn)漢諾塔呢?

第一步要先確定起始位置、中轉(zhuǎn)位置、目的位置,在一開始A是起始位置,B是中轉(zhuǎn)位置,C是目的位置,在后續(xù)移動物塊的時候會一直改變這三個位置的功能,以達到最終目標。

漢諾塔的基本思路是:

第一階段:將n-1個物塊(也就是除最底部的物塊外)經(jīng)過一系列地堆放(這里就可以使用到遞歸的方法來實現(xiàn)),最后放置到中轉(zhuǎn)位置上,然后把起始位置剩下的物塊放到目的位置上,如下圖:

 以上一系列地堆放是指:以A為起始位置,C為中轉(zhuǎn)位置,B為目的位置,也就相當于把C看作是一個中間存放點,來幫助這n-1個物塊放到B里面去。

第二階段:然后會發(fā)現(xiàn),變化后的漢諾塔的形式也和之前是差不多的,如果把B看作是起始位置,A是中轉(zhuǎn)位置,C是目的位置。就可以一直按照上面的那個方法一直遞歸下去,如下圖:

以此類推……最后就能實現(xiàn)把所有的物塊全部從A搬到C。

具體代碼見下(注意點在代碼下面):

//C語言實現(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;
}

注意點一:代碼中的n值不能太大,因為移動次數(shù)是隨n的增大呈指數(shù)倍增長。

注意點二:n為1的時候已近到達最小單位(也就是最底層),不需要使用遞歸;n為大于1的值時,需要遞歸到1才能進行。

注意點三:第一階段使用遞歸表示的是把上面n-1層全部移到B中;而第二階段使用遞歸表示的是把B中全部移到C中。

總結(jié)

這樣就可以簡單地完成漢諾塔,此代碼并不是最優(yōu)方法,但是理解起來比較容易。遞歸在實際中運用的不是很多,但是也要看得懂代碼和寫出類似這種漢諾塔等遞歸函數(shù)的基礎(chǔ)代碼。

到此這篇關(guān)于C語言用遞歸函數(shù)實現(xiàn)漢諾塔的文章就介紹到這了,更多相關(guān)C語言漢諾塔內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言深入淺出分析函數(shù)指針

    C語言深入淺出分析函數(shù)指針

    函數(shù)指針是一個指針變量,它可以存儲函數(shù)的地址,然后使用函數(shù)指針,下面這篇文章主要給大家介紹了關(guān)于C語言進階教程之函數(shù)指針的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • 詳解C++中類的六大默認成員函數(shù)

    詳解C++中類的六大默認成員函數(shù)

    這篇文章主要介紹了C++類中的六大默認成員函數(shù)的原理雨使用,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • bloom filter概念講解以及代碼分析

    bloom filter概念講解以及代碼分析

    Bloom filter 優(yōu)點就是它的插入和查詢時間都是常數(shù),另外它查詢元素卻不保存元素本身,具有良好的安全性
    2013-09-09
  • C++中的string類型

    C++中的string類型

    這篇文章主要介紹了C++中的string類型,在C++當中,除了char 類型,還有專門的字符串類型,就叫做string,下面文字將圍繞其相關(guān)資料展開詳細內(nèi)容,需要的朋友可以參考一下,希望對你有所幫助
    2021-11-11
  • C++ 系統(tǒng)String類詳解

    C++ 系統(tǒng)String類詳解

    這篇文章主要介紹了C++的系統(tǒng)String類,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-11-11
  • C++內(nèi)存對齊的實現(xiàn)

    C++內(nèi)存對齊的實現(xiàn)

    本文主要介紹了C++內(nèi)存對齊的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • C++自定義函數(shù)判斷某年某月某日是這一年中第幾天

    C++自定義函數(shù)判斷某年某月某日是這一年中第幾天

    這篇文章主要介紹了C++自定義函數(shù)判斷某年某月某日是這一年中第幾天的方法,涉及C++日期與時間操作相關(guān)技巧,需要的朋友可以參考下
    2016-06-06
  • 使用C語言詳解霍夫曼樹數(shù)據(jù)結(jié)構(gòu)

    使用C語言詳解霍夫曼樹數(shù)據(jù)結(jié)構(gòu)

    這篇文章主要介紹了使用C語言詳解霍夫曼樹數(shù)據(jù)結(jié)構(gòu),包括一道AMC相關(guān)的例題演示需要的朋友可以參考下
    2015-08-08
  • C語言實現(xiàn)猜數(shù)字小項目

    C語言實現(xiàn)猜數(shù)字小項目

    這篇文章主要為大家詳細介紹了C語實現(xiàn)猜數(shù)字小項目,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C++實現(xiàn)簡易通訊錄功能

    C++實現(xiàn)簡易通訊錄功能

    這篇文章主要為大家詳細介紹了C++實現(xiàn)簡易通訊錄功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06

最新評論