题目
一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。
答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。
看题解后
class Solution {
public int numWays(int n) {
if(n==0||n==1){
return 1;
}
// 两个变量表示前两项
int pre = 1,cur = 2;
for(int i = 3;i<=n;i++){
int temp = (pre+cur) % 1000000007;
// 更新变量
pre = cur;
cur = temp;
}
return cur;
}
}
- 快是真的快,但是不明白是真不明白~
- 看讨论大佬写的想法
第0级:一种方式,就是原地不动;
第1级:1种方式,即从0走一步到第1级;
第2级:2种方式,即从0到1到2,或者直接从0到2;
第3级:考虑每次只能上1或者2级,那么到第三级只有两种情况:从第1级上两步到第3级,或者从第2级走一步到第三级。上面我们又计算了,到第1级只有一种方式,到第二级有2种方式,所以到第三级的方式就有:11+21=3。每一次从前一级或者前二级到当前级都只有一种方式,所以也可以写成:1+2=3。
… …
第n级:同上,到第n级只有两种方式:从n-2级走两步到第n级,或者从n-1级走一步到第n级。假设到第n-2级的方式有
f(n-2)种,到第n-1级的方式有f(n-1)种,则到第n级的方式有:f(n-2)*1+f(n-1)*1=f(n-2)+f(n-1)。