国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

用C程序解決漢諾塔問題與青蛙跳臺階問題(遞歸)

villainhr / 3292人閱讀

摘要:由此可知在前柱是中轉柱在之后也有兩種情況只有上有圓盤。并且我們的游戲目標從一開始的把上所有圓盤移到柱變成了把上所有圓盤移到柱上而在這時中轉柱是柱。現在將步驟分為三個小步驟將上個圓盤全部移到柱上中轉柱柱。

一.漢諾塔問題

? 漢諾塔是一種古印度游戲,該游戲的實質就是在一塊木板上有三根固定的柱子

而在左邊的柱子上有著n個大小不同的圓盤,我們需要做就是把左邊所有的盤子全部移到右邊的柱子上。操作規則:1.圓盤在柱子上必須按照從大到小(大圓盤在下)依次排列。2.每次只能移動圓柱最上面的圓盤。

問題分析:先假設三根柱子分別為“A”"B""C",A柱有著所有的初始盤,我們的目的就是把A柱上的所有盤子全部移到C柱上。

n=1時,直接把圓盤從A柱移動到C柱就可。

n=2時,A-->B,A-->C,B-->C。(在這操作中B為中轉柱)

n=3時,A-->C,A-->B,C-->B,①A-->C,B-->A,B-->C,A-->C。對n=3這種情況進行分析:在①之前圓盤所在圓柱的情況有兩種:

1.是所有圓盤在A,B,C三個圓柱中都有一個圓盤。

2.是A,C上有圓盤而B上沒有圓盤。

由此可知在①前B柱是中轉柱;在①之后也有兩種情況:

1.只有B,C上有圓盤。

2.A,B,C上都有一個圓盤。

并且我們的游戲目標從一開始的把A上所有圓盤移到C柱(A-->C),變成了把B上所有圓盤移到C柱上(B-->C),而在這時中轉柱是A柱。

......

直到A上有n個圓盤時,現在對n這種情況進行分析:想要把n個圓盤從A柱移到C柱上有三大步驟:

①將A上n-1個圓柱全部移到C柱上(中轉柱B柱)。

②將A上的一個圓盤移到C柱上。

③將B上n-1個圓盤全部移到C柱上(中轉柱A柱)。

在這要穿插一下遞歸的主要思想就是大事化小。現在將①步驟分為三個小步驟:

①將A上n-2個圓盤全部移到C柱上(中轉柱B柱)。

②將A上第n-1個圓盤移到B柱上。

③將C上n-2個圓盤移到A柱上(中轉柱A柱)。

然后將第二個①化為更小的三個步驟......就這樣一步步大事化小。

代碼實現:

#includevoid hanoi(int n, char post_1, char post_2, char post_3){    if (n == 1)    {        printf("%c --> %c/n", post_1, post_3);    }    else    {        hanoi(n - 1, post_1, post_3, post_2);        printf("%c --> %c/n", post_1, post_3);        hanoi(n - 1, post_2, post_1, post_3);    }}int main(){    int n = 0;    char a = "A", b = "B", c = "C";    scanf("%d", &n);    hanoi(n, a, b, c);    return 0;}

?二.青蛙跳臺階問題

? 一只青蛙一次可以跳上1級臺階,也可以跳上2級臺階。求該青蛙跳上一個n級臺階有多少種跳法?(實質就是斐波那契數列的變種)

問題分析:

我們不妨列舉一下n比較少的情況時的跳法:

①n=1時,1種跳法。????????? ②n=2時,有2種跳法。

③n=3時,有3種跳法。????? ④n=4時,有5種跳法。

⑤n=5時,有8種跳法。

......

很明顯,同過觀察上面列舉的情況可以發現:

n=3時所有的跳法等于n=1時和n=2時的所有跳法之和;

n=4時的所有跳法等于n=2和n=3時的所有跳法之和;

......

以此類推可以得出f(n)=f(n-1)+f(n-2) (n>2)。(f(n)為跳法數量)

?

代碼實現:

#includeint frogjump(int n){	if (n == 1)	{		return 1;	}	else if (n == 2)	{		return 2;	}	else	{		return frogjump(n - 1) + frogjump(n - 2);	}}int main(){	int n = 0;	scanf("%d", &n);	printf("%d", frogjump(n));	return 0;}

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/123073.html

相關文章

  • 看動畫輕松理解「遞歸「動態規劃」

    摘要:程序員小吳打算使用動畫的形式來幫助理解遞歸,然后通過遞歸的概念延伸至理解動態規劃算法思想。因此,分治策略一般用來解決子問題相互對立的問題,稱為標準分治,而動態規劃用來解決子問題重疊的問題。難點就在于找出動態規劃中的這三個概念。 在學習「數據結構和算法」的過程中,因為人習慣了平鋪直敘的思維方式,所以「遞歸」與「動態規劃」這種帶循環概念(繞來繞去)的往往是相對比較難以理解的兩個抽象知識點。...

    cnio 評論0 收藏0
  • 數據結構算法之漢諾問題(Java遞歸

    摘要:漢諾塔問題有三根柱子,源桿,暫存桿,目的桿上有層盤子,由小到大向下排列,現需要將桿的盤子移到桿中要求大的盤在下面,小的盤在上面一次只能移動一個盤子個人思路先分析問題,用數學的歸納法當只有一個盤時,直接移動當有兩個盤時,先將小的移到暫存桿,再 漢諾塔問題: 有三根柱子,源桿A,暫存桿temp,目的桿C A上有n層盤子,由小到大向下排列,現需要將A桿的盤子移到C桿中 ...

    yuxue 評論0 收藏0
  • 一個小青蛙,可以一次兩節樓梯,也可以一次一節樓梯,請問他如果要101節樓梯,一共有幾種法方案

    摘要:一個小青蛙可以一次跳兩節樓梯也可以一次跳一節樓梯請問他如果要跳節樓梯一共有幾種跳法方案問題的描述很簡單看到這個題目的時候我首先想到的就是舉例分析一波比如當的時候有幾種方案當的時候有幾種方案等等我們首先分析一波當的時候這個時候小青蛙只有一種跳 一個小青蛙,可以一次跳兩節樓梯,也可以一次跳一節樓梯,請問他如果要跳101節樓梯,一共有幾種跳法方案? 問題的描述很簡單,看到這個題目的時候,我首...

    fsmStudy 評論0 收藏0
  • 經典算法:漢諾

    摘要:學編程,學,算法也是必不可缺的,這一次給大家帶來一個經典的遞歸算法題,漢諾塔。當我們把層都搬到了中間柱的時候,只需要把最大的那個盤,從搬到柱就好了,剩下的怎么辦呢柱永遠是目標柱,我們不需要去移動它。 學編程,學IT,算法也是必不可缺的,這一次給大家帶來一個經典的遞歸算法題,漢諾塔。算是算法的入門小題目之一吧~ 視頻教程 什么是漢諾塔? 我這里直接拉來一個圖解釋一下(掛了請聯系我)sho...

    Lin_R 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<