C語言 遞歸解決青蛙跳臺(tái)階問題
前言
一只青蛙一次可以跳1級(jí)或2級(jí)臺(tái)階,求當(dāng)臺(tái)階數(shù)為n時(shí)青蛙有多少種跳法。
一、求解思路
臺(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é)果
總結(jié)
孤寡 孤寡 孤寡
到此這篇關(guān)于C語言 遞歸解決青蛙跳臺(tái)階問題的文章就介紹到這了,更多相關(guān)C語言 遞歸內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++創(chuàng)建窗口程序的實(shí)現(xiàn)示例
Windows窗體應(yīng)用程序是C#語言中的一個(gè)重要應(yīng)用,本文主要介紹了C++創(chuàng)建窗口程序的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01Matlab利用隨機(jī)森林(RF)算法實(shí)現(xiàn)回歸預(yù)測(cè)詳解
這篇文章主要為大家詳細(xì)介紹了Matlab如何利用隨機(jī)森林(RF)算法實(shí)現(xiàn)回歸預(yù)測(cè),以及自變量重要性排序的操作,感興趣的小伙伴可以了解一下2023-02-02C語言實(shí)現(xiàn)統(tǒng)計(jì)一行字符串的單詞個(gè)數(shù)
這篇文章主要介紹了C語言實(shí)現(xiàn)統(tǒng)計(jì)一行字符串的單詞個(gè)數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07深入剖析Android中init進(jìn)程實(shí)現(xiàn)的C語言源碼
這篇文章主要介紹了Android中init進(jìn)程實(shí)現(xiàn)的C語言源碼,init屬性服務(wù)在安卓中屬于系統(tǒng)的底層Linux服務(wù),需要的朋友可以參考下2015-07-07C語言實(shí)現(xiàn)停車場(chǎng)項(xiàng)目
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)停車場(chǎng)項(xiàng)目,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03數(shù)據(jù)結(jié)構(gòu)C語言鏈表的實(shí)現(xiàn)介紹
大家好,本篇文章主要講的是數(shù)據(jù)結(jié)構(gòu)C語言鏈表的實(shí)現(xiàn)介紹,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下2021-12-12c++中虛函數(shù)和純虛函數(shù)的作用與區(qū)別
這篇文章主要介紹了c++中虛函數(shù)和純虛函數(shù)的作用與區(qū)別,需要的朋友可以參考下2014-07-07