题目(leecode T70):
假设你正在爬楼梯。需要 n
阶你才能到达楼顶。
每次你可以爬 1
或 2
个台阶。你有多少种不同的方法可以爬到楼顶呢?
方法:本题是一个背景类的题目,需要我们从题目的背景中抽象出我们需要的内容,其实我们上楼梯的过程也是一个动态规划的过程,这一步的状态可以由你前一步或前两步的状态推导得到,因为一次只能走一步或两步。到第i层楼梯的话可以由i-1层楼梯走一步或者由i-2层楼梯走两步得到。因此第i层的方法是dp[i-1]+dp[i-2]。
1:dp数组含义:dp[i]代表到第i层楼梯可走的方法
2:初始化:第0层楼梯不在我们的考虑范围。dp[1]=1,dp[2]=2
3:递推公式:分析得到:dp[i]=dp[i-1]+dp[i-2]
4:遍历顺序:从前往后
5:举例模拟:前五个是12358
我们会发现这就是斐波那契数,只是没有dp[0]的情况而已
题解:
class Solution {
public:
int climbStairs(int n) {
if(n <= 1) return n;
vector<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];
}
};