509. 斐波那契数
很简单的动规入门题,但简单题使用来掌握方法论的,还是要有动规五部曲来分析。
视频:手把手带你入门动态规划 | LeetCode:509.斐波那契数_哔哩哔哩_bilibili
class Solution {
public:
int fib(int n) {
int dp[n+1];
if (n<2)return n;
dp[0]=0;dp[1]=1;
for (int i=2;i<=n;i++){
dp[i]=dp[i-1]+dp[i-2];
}
return dp[n];
}
};
70. 爬楼梯
本题大家先自己想一想, 之后会发现,和 斐波那契数 有点关系。
视频:带你学透动态规划-爬楼梯(对应力扣70.爬楼梯)| 动态规划经典入门题目_哔哩哔哩_bilibili
class Solution {
public:
int climbStairs(int n) {
int dp[n+1];
if (n<=2)return n;
dp[0]=0;dp[1]=1;dp[2]=2;
for (int i=3;i<=n;i++){
dp[i]=dp[i-1]+dp[i-2];
}
return dp[n];
}
};
746. 使用最小花费爬楼梯
这道题目力扣改了题目描述了,现在的题目描述清晰很多,相当于明确说 第一步是不用花费的。
更改题目描述之后,相当于是 文章中 「拓展」的解法
视频讲解:动态规划开更了!| LeetCode:746. 使用最小花费爬楼梯_哔哩哔哩_bilibili
class Solution {
public:
int minCostClimbingStairs(vector<int>& cost) {
int len=cost.size();
int dp[len+1];
if (len<2)return cost[len-1];
dp[0]=0;dp[1]=cost[0];dp[2]=cost[1];
for (int i=3;i<=len;i++){
dp[i]=min(dp[i-1],dp[i-2])+cost[i-1];
}
return min(dp[len],dp[len-1]);
}
};