题目:
分析:
这道题我们可以用动态规划的原理来做
我们将每个楼梯的方案数列出来
我们可以很清楚的发现
dp[i]=dp[i-1]+dp[i-2]
道理也很简单
dp[i]的方案数 =(dp[i-1]的方案数+一阶台阶)+(dp[i-2]的方案数+二阶台阶)
代码:
class Solution {
public int climbStairs(int n) {
if(n==1) return 1;
int [] dp=new int[n+1];
dp[1]=1;
dp[2]=2;
for(int i=3;i<=n;i++)
dp[i]=dp[i-1]+dp[i-2];
return dp[n];
}
}