二刷代码随想录训练营Day 32|动态规划理论基础、509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯

1.理论基础

代码随想录

视频:从此再也不怕动态规划了,动态规划解题方法论大曝光 !| 理论基础 |力扣刷题总结| 动态规划入门_哔哩哔哩_bilibili

2.斐波那契数

代码随想录

视频:手把手带你入门动态规划 | LeetCode:509.斐波那契数_哔哩哔哩_bilibili

代码:

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

note:

dp数组的含义:第i个下标对应的斐波那契数列值是dpi ,因此要求得dpn,数组要有n+1个元素

递推公式:dpi = dpi - 1 + dpi - 2

dp数组初始化:初始化前两个元素即可------dp0 = 0 dp1 = 1

遍历顺序:从前向后遍历------因为后面的元素要依靠前面的元素得出

3.爬楼梯

代码随想录

视频:带你学透动态规划-爬楼梯(对应力扣70.爬楼梯)| 动态规划经典入门题目_哔哩哔哩_bilibili

代码:

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if(n <= 2) return n;
        vector<int> dp(n + 1,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];
    }
};

note:

dp数组的含义:爬到第i个楼梯所用的方法数是dpi

递推公式:爬到第i个楼梯,可以从第i-1个楼梯往上爬,也可以从第i - 2个楼梯往上爬。因此,爬到第i个楼梯的方法数 = dpi = dpi - 1 + dpi - 2

dp数组初始化:从实际意义考虑,我们初始化第1个和第2个台阶的方法数是1 和 2。

遍历顺序:从前向后遍历------因为后面的元素要依靠前面的元素得出

这道题的dp数组其实就是斐波那契数列。

4.使用最小花费爬楼梯

代码随想录

视频讲解:动态规划开更了!| LeetCode:746. 使用最小花费爬楼梯_哔哩哔哩_bilibili

代码:

cpp 复制代码
class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        if(cost.size() < 2) return 0;
        vector<int> dp(cost.size() + 1,0);
        dp[0] = 0;
        dp[1] = 0;
        for(int i = 2; i <= cost.size(); i++){
            dp[i] = min((dp[i - 1] + cost[i - 1]),(dp[i - 2] + cost[i - 2]));
        }
        return dp[cost.size()];
    }
};

note:

注意这里是要爬到楼顶,也就是爬到cost.size()层,对应的dp数组大小是cost.size() + 1

dp数组的含义:爬到第i个台阶所用的最小花费是dpi

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

dp数组的初始化:初始化dp0 = 0 dp1 = 0,因为题上说可以从i= 0和i= 1的台阶开始爬

遍历顺序:从前向后遍历------因为后面的元素要依靠前面的元素得出

相关推荐
点云侠7 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法
代码中介商7 小时前
跳表:高效查找的链表黑科技
数据结构
兰令水7 小时前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode
临沂堇7 小时前
刷题日志 | Leetcode Hot 100 哈希
算法·leetcode·哈希算法
.道阻且长.7 小时前
C++ string 操作指南:接口解析
java·c语言·开发语言·c++
玉小格7 小时前
一次关于Python的总结
算法
伊甸37 小时前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战
java·算法·缓存
laplaya8 小时前
使用 vcpkg 管理 C++ 项目中的依赖
开发语言·c++
bIo7lyA8v8 小时前
算法中的随机化思想及其复杂度收益评估的技术8
算法
数据法师8 小时前
视频文件重复检测工具:基于哈希与视频指纹的三级筛选机制
算法·音视频·哈希算法