溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

C語言中如何使用遞歸解決青蛙跳臺(tái)階問題

發(fā)布時(shí)間:2021-11-20 14:33:42 來源:億速云 閱讀:195 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹C語言中如何使用遞歸解決青蛙跳臺(tái)階問題,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

一、求解思路

臺(tái)階的數(shù)量為n。

當(dāng) n = 1 時(shí),青蛙有一種跳法,即跳1級(jí)臺(tái)階。

當(dāng) n = 2 時(shí),青蛙有兩種跳法,即跳兩次1級(jí)臺(tái)階或跳一次2級(jí)臺(tái)階。

當(dāng) n = 3 時(shí),青蛙可以先跳2級(jí)臺(tái)階再跳1級(jí)臺(tái)階,也可以選擇先跳1級(jí)臺(tái)階再跳2級(jí)臺(tái)階,或者是跳三次1級(jí)臺(tái)階。依次類推,我們就能知道臺(tái)階數(shù)為n時(shí)青蛙的跳法。

但是,這樣子是不是很麻煩呢,再仔細(xì)想一下。

還是當(dāng) n = 3 時(shí),我們選擇先跳1級(jí)臺(tái)階,剩下的2級(jí)臺(tái)階的跳法,是不是就是當(dāng) n = 2 時(shí)青蛙的跳法;我們選擇先跳2級(jí)臺(tái)階,剩下的1級(jí)臺(tái)階的跳法,是不是就是當(dāng) n = 1 時(shí)青蛙的跳法。

由此可知,n = 3 時(shí)青蛙的跳法為 n = 1 時(shí)的跳法加上 n = 2 時(shí)的跳法。

當(dāng) n = N 時(shí),N個(gè)臺(tái)階的跳法為 N-1 的跳法加上 N-2 的跳法。

乍一看,是不是感覺和斐波那契數(shù)列有點(diǎn)像,當(dāng)然,還是有一丟丟不一樣的,不過我們可以用同樣的數(shù)學(xué)思想來解決這個(gè)問題。

二、代碼實(shí)現(xiàn)

1.參考代碼

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
 
int flog(int n)
{
	if (n == 1)	
		return 1;	
	else if (n == 2)
		return 2;	
	else
		return flog(n - 1) + flog(n - 2);
}
int  main()
{
	int n = 0;
    int ways = 0;
	printf("請(qǐng)輸入臺(tái)階的數(shù)量:");
	scanf("%d", &n);
	ways = flog(n);
	printf("青蛙有%d種跳法",ways);
	return 0;
}

2.運(yùn)行結(jié)果

C語言中如何使用遞歸解決青蛙跳臺(tái)階問題

以上是“C語言中如何使用遞歸解決青蛙跳臺(tái)階問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI