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

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.最小代价爬楼梯

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

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

因此递推公式:dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 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];
    }
};
相关推荐
Jing_Rainbow4 分钟前
【LeetCode Hot100 刷题日记(19/100)】54. 螺旋矩阵 —— 数组、矩阵、模拟、双指针、层序遍历🌀
算法·面试·程序员
地平线开发者1 小时前
征程 6 | linear 高精度输出配置方式
算法·自动驾驶
小尧嵌入式1 小时前
C++基础语法总结
开发语言·c++·stm32·单片机·嵌入式硬件·算法
white-persist1 小时前
【攻防世界】reverse | IgniteMe 详细题解 WP
c语言·汇编·数据结构·c++·python·算法·网络安全
稚辉君.MCA_P8_Java1 小时前
Gemini永久会员 归并排序(Merge Sort) 基于分治思想(Divide and Conquer)的高效排序算法
java·linux·算法·spring·排序算法
地平线开发者2 小时前
征程 6 | QAT 新版 qconfig 量化模板使用教程
算法·自动驾驶
多恩Stone2 小时前
【ModelScope-1】数据集稀疏检出(Sparse Checkout)来下载指定目录
人工智能·python·算法·aigc
山峰哥2 小时前
沉浸式翻译插件深度评测:打破语言壁垒的黑科技利器
数据结构·科技·算法·编辑器·办公
AI脚下的巨人2 小时前
机器人逆运动学:从SVD到IK算法
算法·机器人
ゞ 正在缓冲99%…3 小时前
2025.9.28华为软开
算法·华为