C語言 遞歸解決青蛙跳臺階問題

前言
一只青蛙一次可以跳1級或2級臺階,求當(dāng)臺階數(shù)為n時青蛙有多少種跳法。
一、求解思路
臺階的數(shù)量為n。
當(dāng) n = 1 時,青蛙有一種跳法,即跳1級臺階。
當(dāng) n = 2 時,青蛙有兩種跳法,即跳兩次1級臺階或跳一次2級臺階。
當(dāng) n = 3 時,青蛙可以先跳2級臺階再跳1級臺階,也可以選擇先跳1級臺階再跳2級臺階,或者是跳三次1級臺階。依次類推,我們就能知道臺階數(shù)為n時青蛙的跳法。
但是,這樣子是不是很麻煩呢,再仔細(xì)想一下。
還是當(dāng) n = 3 時,我們選擇先跳1級臺階,剩下的2級臺階的跳法,是不是就是當(dāng) n = 2 時青蛙的跳法;我們選擇先跳2級臺階,剩下的1級臺階的跳法,是不是就是當(dāng) n = 1 時青蛙的跳法。
由此可知,n = 3 時青蛙的跳法為 n = 1 時的跳法加上 n = 2 時的跳法。
當(dāng) n = N 時,N個臺階的跳法為 N-1 的跳法加上 N-2 的跳法。
乍一看,是不是感覺和斐波那契數(shù)列有點像,當(dāng)然,還是有一丟丟不一樣的,不過我們可以用同樣的數(shù)學(xué)思想來解決這個問題。
二、代碼實現(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("請輸入臺階的數(shù)量:");
scanf("%d", &n);
ways = flog(n);
printf("青蛙有%d種跳法",ways);
return 0;
}
2.運行結(jié)果

總結(jié)
孤寡 孤寡 孤寡
到此這篇關(guān)于C語言 遞歸解決青蛙跳臺階問題的文章就介紹到這了,更多相關(guān)C語言 遞歸內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
QT連接Mysql數(shù)據(jù)庫的實現(xiàn)步驟
本文主要介紹了QT連接Mysql數(shù)據(jù)庫的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
詳解C語言 三大循環(huán) 四大跳轉(zhuǎn) 和判斷語句
這篇文章主要介紹了詳解C語言 三大循環(huán) 四大跳轉(zhuǎn) 和判斷語句的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-07-07
Visual Studio 2019配置qt開發(fā)環(huán)境的搭建過程
這篇文章主要介紹了Visual Studio 2019配置qt開發(fā)環(huán)境的搭建過程,本文圖文并茂給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03
C++實現(xiàn)LeetCode(57.插入?yún)^(qū)間)
這篇文章主要介紹了C++實現(xiàn)LeetCode(57.插入?yún)^(qū)間),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
Sublime Text 3 實現(xiàn)C++代碼的編譯和運行示例
下面小編就為大家?guī)硪黄猄ublime Text 3 實現(xiàn)C++代碼的編譯和運行示例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09

