代码随想录第二十天:动态规划、斐波那契数列、爬楼梯、最小体力爬楼梯

1.动态规划理论

理论讲解链接:代码随想录 (programmercarl.com)

对于动态规划问题,可以拆解为如下五步曲

  1. 确定dp数组(dp table)以及下标的含义
  2. 确定递推公式
  3. dp数组如何初始化
  4. 确定遍历顺序
  5. 举例推导dp数组

2.斐波那契数列

dp数组元素的含义是对应斐波那契数列的元素。

递推公式F(n) = F(n - 1) + F(n - 2)。

初始化F(0) = 0,F(1) = 1。

遍历顺序从前向后。

代码如下:

cpp 复制代码
class Solution{
public:
    int fib(int n) {
        if (n == 0 || n == 1) return n;
        vector<int> dp(n + 1, 0);
        dp[0] = 0;
        dp[1] = 1;
        for (int i = 2; i < n + 1; ++i) {
            dp[i] = dp[i - 1] + dp[i - 2];
        }
        return dp[n];
    }
};

3.爬楼梯

本题的关键逻辑是当前阶梯,可以由上一节阶梯走一步或者由上上一节阶梯走两步得来,所以走到当前阶梯的方法是去上一节阶梯的方法加上去上上一节阶梯的方法。

因此得到递推公式:F(n) = F(n - 1) + F(n - 2),所以本题所求就是斐波那契数列。

代码如下:

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if (n == 0 || n == 1) return n;
        vector<int> dp(n + 1, 0);
        dp[0] = 0;
        dp[1] = 1;
        for (int i = 2; i < n + 1; ++i) {
            dp[i] = dp[i - 1] + dp[i - 2];
        }
        return dp[n];
    }
};

3.最小代价爬楼梯

本题为每个楼梯添加了攀爬的代价,可以选择从前两层开始爬。

爬到每层的代价是爬到前一层的代价加上前一层继续前进花费的代价,或者是前两层的代价加上继续前进的代价,最小代价取二者最小值即可。

因此递推公式:dpi = min(dpi - 1 + costi - 1, dpi - 2 + costi - 2);

代码如下:

cpp 复制代码
class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        if (cost.size() == 0 || cost.size() == 1) return 0;
        vector<int> dp(cost.size(), 0);
        for (int i = 0; i < dp.size() ; ++i) {
            dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);
        }
        return dp[cost.size() - 1];
    }
};
相关推荐
智者知已应修善业11 分钟前
【51单片机8位数码管同时倒计时从9999】2024-1-25
c++·经验分享·笔记·算法·51单片机
洛水水14 分钟前
【力扣100题】86.柱状图中最大的矩形
算法·leetcode·职场和发展
渡之21 分钟前
GRiM-Net 深度解析 | 无人机 GNSS 拒止场景下两阶段跨视角视觉定位框架
深度学习·算法·动态规划·无人机
测试仪器廖生1359025638540 分钟前
罗德与施瓦茨 FSP13频谱分析仪FSP30
网络·人工智能·算法
happymaker062643 分钟前
LeetCodeHot100——560.和为K的子数组
算法
dtq04241 小时前
C语言刷题数组5,6(求平均值,求最大值)
c语言·数据结构·算法
郭梧悠1 小时前
Hash算法入门Hash冲突解决方案
算法·哈希算法
洛水水2 小时前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode
happymaker06262 小时前
LeetCodeHot100——155.最小栈
算法
洛水水2 小时前
【力扣100题】85.每日温度
算法·leetcode·职场和发展