假设你正在爬楼梯。需要 n
阶你才能到达楼顶。
每次你可以爬 1
或 2
个台阶。你有多少种不同的方法可以爬到楼顶呢?
示例 1:
输入:n = 2 输出:2 解释:有两种方法可以爬到楼顶。 1. 1 阶 + 1 阶 2. 2 阶
有多少种不同的方法可以到达楼顶呐?首先达到楼顶有两种方式,一是最后一次走了两个阶梯,每一是最后一次只走了一次楼梯。
这个时候就可以用动态规划的方法
1、dp[i]的含义是:爬到第i层阶梯有dp[i]种方式
2、确定递推公式:dp[i]=max(dp[i-1],dp[i-2])
3、初始化:dp[1]=1;dp[2]=2
4、确定遍历顺序:从前往后遍历
5、距离推导dp数组
code
class Solution
{
public:
int climbStairs(int n)
{
if (n <= 1)return n;
vector<int>dp(n+1);
for (int i = 3; i < n; i++)
{
dp[i] = dp[i - 1] + dp[i - 2];
}
return dp[n];
}
};