Java青蛙跳臺(tái)階問題的解決思路與代碼
問題描述
一只青蛙一次可以跳上1級臺(tái)階,也可以一次跳上2級臺(tái)階,請問跳上n級臺(tái)階,該請娃一共有多少種跳法?
解決思路
①如果只有1級臺(tái)階,那顯然只有一種跳法。
②如果有2級臺(tái)階,那么就有2種跳法,一種是分2次跳。每次跳1級,另一種就是一次跳2級。
③如果臺(tái)階級數(shù)大于2,設(shè)為n的話,這時(shí)我們把n級臺(tái)階時(shí)的跳法看成n的函數(shù),記為,第一次跳的時(shí)候有2種不同的選擇:一是第一次跳一級,此時(shí)跳法的數(shù)目等于后面剩下的n-1級臺(tái)階的跳法數(shù)目,即為,二是第一次跳二級,此時(shí)跳法的數(shù)目等于后面剩下的n-2級臺(tái)階的跳法數(shù)目,即為,因此n級臺(tái)階的不同跳法的總數(shù)為,不難看出就是斐波那契數(shù)列。

實(shí)現(xiàn)代碼
1.青蛙跳臺(tái)階遞歸方法
public static int f1(int n){
if(n==1||n==2){
return n;
}
else{
return f1(n-1)+f1(n-2);
}
}
2.青蛙跳臺(tái)階非遞歸方法
public static int f2(int m){
if(m==1||m==2){
return m;
}
int a1 = 1;
int a2 = 2;
int result = 0;
for (int i = 3; i <= m; i++) {
result = a1 + a2;
a1 = a2;
a2 = result;
}
return result;
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int num = sc.nextInt();
System.out.println("遞歸青蛙跳"+num+"級臺(tái)階共有"+f1(num)+"種方法!");
System.out.println("非遞歸青蛙跳"+num+"級臺(tái)階共有"+f2(num)+"種方法!");
}
運(yùn)行結(jié)果:

總結(jié)
到此這篇關(guān)于Java青蛙跳臺(tái)階問題的解決思路與代碼的文章就介紹到這了,更多相關(guān)Java青蛙跳臺(tái)階內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java 遍歷Map及Map轉(zhuǎn)化為二維數(shù)組的實(shí)例
這篇文章主要介紹了java 遍歷Map及Map轉(zhuǎn)化為二維數(shù)組的實(shí)例的相關(guān)資料,希望通過本文能幫助到大家,實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-08-08
ImportBeanDefinitionRegistrar手動(dòng)控制BeanDefinition創(chuàng)建注冊詳解
這篇文章主要為大家介紹了ImportBeanDefinitionRegistrar手動(dòng)控制BeanDefinition創(chuàng)建注冊詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
Java圖片讀取ImageIO.read()報(bào)錯(cuò)問題及解決
在使用imageio庫讀取圖片時(shí),如果路徑中包含中文,可能會(huì)導(dǎo)致讀取失敗,解決方法是將路徑中的中文字符進(jìn)行轉(zhuǎn)義處理,可以使用ImageUtil.java工具類進(jìn)行路徑轉(zhuǎn)義,從而避免錯(cuò)誤,這是一個(gè)常見問題,希望本文的解決方案能幫助到遇到相同問題的開發(fā)者2024-10-10
Spring之動(dòng)態(tài)注冊bean的實(shí)現(xiàn)方法
這篇文章主要介紹了Spring之動(dòng)態(tài)注冊bean的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-08-08
Spring與Shiro整合及加載權(quán)限表達(dá)式問題
這篇文章主要介紹了Spring與Shiro整合及加載權(quán)限表達(dá)式問題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12

