斐波那契数列的编程题,青蛙跳台
一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。
答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。
思路
分为最后一步只 跳一级台阶,说明到达了 n-1台阶,有 f(n-1) 种跳法
最后一步,跳2 级台阶,说明达到了 n-2 台阶, 有 f(n-2) 种跳法
所以到达 n台阶 有f(n) = f(n-1) + f(n-2) 种跳法
其实就是斐波那契数列,有一点区别
斐波那契数列 f(1) =1,f(2)=1
青蛙跳台阶 f(1) =1, f(2)=2
代码
int[] arr = new int[n+1];
arr[1]=1;
arr[2]=2;
for(int i=3;i<=n;i++){
arr[i] = (arr[i-1]+arr[i-2])%1000000007;
}
return arr[n];
或者
int a=1,b=2,sum;
for(int i=3;i<=n;i++){
sum = (a+b)%1000000007;
a=b;
b=sum;
}
return sum;