(1)思路:
DP问题:
(1)确定数组含义:dp[i]表示跳到第i阶的方法数;
(2)找出数组元素间的关系:跳到第i阶,可以一步跳上来,也可以两步跳上来,所以dp[i]=dp[i-1]+dp[i-2];
(3)找出初始值:dp[0]=1,dp[1]=1;
代码:
class Solution {
public int numWays(int n) {
if(0 == n)
return 1;
int[] dp = new int[n+1];
dp[0] = 1;
dp[1] = 1;
for(int i = 2; i<n+1; i++)
{
dp[i] = (dp[i-1] + dp[i-2]) % 1000000007;
}
return dp[n];
}
}
复杂度分析:
Time:O(N)
Space:O(N)
注意:
(1)由于DP下标的实际意义是1~n,所以数组声明长度为n+1;
(2)第0项并不具有实际意义,可按需调节其值;
(2)方法优化:
数组占用较多空间,三者用变量代替;
代码:
int numWays(int n){
int a,b,t;
if(0 == n) return 1;
if(1 == n) return 1;
if(2 == n) return 2;
/* 进入迭代之前,三者必须要有具体值! */
a = 1;
b = 2;
t = a + b;
for(int i = 3; i<n; i++){
a = b;
b = t;
t = (a+b)%1000000007;
}
return t;
}
复杂度分析:
Time:O(N)
Space:O(1)
图解:
Tips:
Java支持声明并初始化变量长度的数组,自动初始化为0;
C支持声明变量长度的数组,但不能同时初始化,需要另外赋值初始化;
所以,对于数组等数据结构建议用Java,链表建议用C!!!