爬楼梯
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
解题思路:
在n-1阶时向上爬1阶可到达楼顶,在n-2阶时向上爬2阶可到达楼顶,因此到到楼顶的爬法等于到达n-1阶和到达n-2阶的爬法之和。
class Solution {
public:
int climbStairs(int n) {
if(n <= 3)return n;
int dp[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];
}
};