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

C語言實現(xiàn)漢諾塔(圖文詳解)

 更新時間:2021年08月13日 15:07:44   作者:流浪孤兒  
個人覺得漢諾塔這個遞歸算法比電子老鼠的難了一些,不過一旦理解了也還是可以的,其實網(wǎng)上也有很多代碼,可以直接參考。記得大一開始時就做過漢諾塔的習題,但是那時代碼寫得很長很長,也是不理解遞歸的結果。今天重新來實現(xiàn)一下

漢諾塔的游戲規(guī)則:

有三根金剛石柱子A、B、C,在A柱子上從下往上按照大小依次減小的順序摞著64片黃金環(huán)。大梵天命令婆羅門把環(huán)從下面開始按大小順序重新擺放在另一根柱子上。并且規(guī)定,在任何一個柱子上,小環(huán)上不能放大環(huán),在三根柱子之間一次只能移動一個環(huán)。

即將A柱子上全部的環(huán)通過中間柱子B(B柱子作為中介)移動到C柱子上

當A只有一個環(huán)的時候:

A->C

當A只有兩個環(huán)的時候:

A->B A->C B->C

當A只有三個環(huán)的時候:

A->C A->B C->B A->C B->A B->C A->C

思路:

1、將 n-1個環(huán)先放到B柱子上
2、將A柱子上的最后一個環(huán)移動到C柱子上
3、將n-1個環(huán)從B柱子移動到C柱子上

當n=1時:

1、將0個環(huán)先放到B柱子上

2、將A柱子上的最后一個環(huán)移動到C柱子上:A->C

3、將0個環(huán)從B柱子移動到C柱子上

當n=2時:

1、將1個環(huán)先放到B柱子上:A->B

2、將A柱子上的最后一個環(huán)移動到C柱子上:A->C

3、將1個環(huán)從B柱子移動到C柱子上:B->C

當n=3時:

1、將2個環(huán)先放到B柱子上:使用遞歸將2個環(huán)放到B上,因為A柱子的最后一個環(huán)是最大的因此可以先不理會,遞歸重復當n=2時的步驟,不過是從將2個環(huán)從A放到C上改為將2個環(huán)從A放到B上了

2、將A柱子上的最后一個環(huán)移動到C柱子上:A->C

3、將2個環(huán)從B柱子移動到C柱子上:使用遞歸將2個環(huán)從B柱子移動到C柱子上,此時C柱子上已經(jīng)有了最大的一個環(huán)因此可以不用再理會了,遞歸重復當n=2的步驟,不過是從將2個環(huán)從A放到C上改為將2個環(huán)從B放到C上了

當n=4時:

1、將3個環(huán)先放到B柱子上:遞歸重復n=3的步驟,不過是從將3個環(huán)從A放到C上改為將3個環(huán)從A放到B上了

2、將A柱子上的最后一個環(huán)移動到C柱子上:A->C

3、將3個環(huán)從B柱子移動到C柱子上:遞歸重復當n=3的步驟,不過是從將3個環(huán)從A放到C上改為將3個環(huán)從B放到C上了

見代碼

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
void move(char X, char Y)
{
	printf("%c->%c ", X, Y);
}

void HanoiTower(int n, char A, char B, char C)
{
	if (n == 1)//遞歸終止條件
	{
		move(A, C);
		return;
	}
		
	else
	{
		HanoiTower(n - 1, A, C, B);//將n-1個環(huán)從A柱子放到B柱子上,C柱子作為中介
		move(A, C);//將A柱子上的最后一個環(huán)移動到C柱子上
		HanoiTower(n - 1, B, A, C);//將n-1個環(huán)從B柱子放到C柱子上,A柱子作為中介
	}
}


int main()
{
	printf("請確認A柱子上一共有多少個環(huán):\n");
	int n = 0;
	scanf("%d", &n);
	HanoiTower(n, 'A','B','C');//將n個環(huán)從A柱子放到C柱子上,B柱子作為中介
}

運行截圖

總結

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

相關文章

  • C語言結構體內存對齊詳解

    C語言結構體內存對齊詳解

    大家好,本篇文章主要講的是C語言結構體內存對齊詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • vscode使用官方C/C++插件無法進行代碼格式化問題

    vscode使用官方C/C++插件無法進行代碼格式化問題

    這篇文章主要介紹了vscode使用官方C/C++插件無法進行代碼格式化問題,本文通過截圖實例代碼相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • C++數(shù)據(jù)結構之哈希算法詳解

    C++數(shù)據(jù)結構之哈希算法詳解

    這篇文章主要為大家詳細介紹了C++數(shù)據(jù)結構中哈希算法的相關資料,文中的示例代碼講解詳細,具有一定的借鑒價值,希望對大家有所幫助
    2022-12-12
  • 淺談C++為什么非要引入那幾種類型轉換

    淺談C++為什么非要引入那幾種類型轉換

    這篇文章主要介紹了C++為什么非要引入那幾種類型轉換,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • c語言同名標靶點自動匹配算法實現(xiàn)實例代碼

    c語言同名標靶點自動匹配算法實現(xiàn)實例代碼

    這篇文章主要介紹了c語言同名標靶點自動匹配算法實現(xiàn)實例代碼,分享了相關代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • C語言將日期、時間保存到文本文件中的方法

    C語言將日期、時間保存到文本文件中的方法

    這篇文章主要給大家介紹了關于C語言將日期、時間保存到文本文件中的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用C語言具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-04-04
  • C++、Qt分別讀寫xml文件的方法實例

    C++、Qt分別讀寫xml文件的方法實例

    Qt提供了QDomElement 類用于完成對xml文件的讀取和寫入,這篇文章主要給大家介紹了關于C++、Qt分別讀寫xml文件的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-03-03
  • C++實現(xiàn)字符串切割的兩種方法

    C++實現(xiàn)字符串切割的兩種方法

    這篇文章主要介紹了C++實現(xiàn)字符串切割的兩種方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 基于C語言編寫一個簡單的Web服務器

    基于C語言編寫一個簡單的Web服務器

    C語言可以干大事,這篇文章主要為大家詳細介紹了如何基于C語言可以完成一個簡易的Web服務器,希望這篇文章會幫你你對C語言有更深入的理解
    2024-03-03
  • C++深入探究不同的繼承體系

    C++深入探究不同的繼承體系

    繼承是C++面向對象編程中的一門。繼承是子類繼承父類的特征和行為,或者是繼承父類得方法,使的子類具有父類得的特性和行為。重寫是子類對父類的允許訪問的方法實行的過程進行重新編寫,返回值和形參都不能改變。就是對原本的父類進行重新編寫,但是外部接口不能被重寫
    2022-05-05

最新評論