代码随想录算法训练营第27天 -- 动态规划1 || 509.斐波那契数列 / 70.爬楼梯 / 746.使用最小花费爬楼梯

代码随想录算法训练营第27天 -- 动态规划1 || 509.斐波那契数列 / 70.爬楼梯 / 746.使用最小花费爬楼梯

动态规划基础

1.动态规划的类型分为:

  1. 动规基础
  2. 背包问题
  3. 打家劫舍
  4. 股票问题
  5. 子序列问题

2.动态规划五部曲

  1. dp 数组以及下标的含义
  2. 递推公式
  3. dp 数组如何初始化
  4. 遍历顺序
  5. 打印 dp 数组

509.斐波那契数列

解题思路

1.dp[i]:第 i 哥斐波那契数的值为 dp[i]

2.确定递推公式:dp[i] = dp[i - 1] + dp[i - 2]

3.dp 数组初始化:dp[0] = 0; dp[1] = 1

4.确定遍历顺序:从前向后

完整代码:

cpp 复制代码
class Solution {
public:
    int fib(int n) {
        if (n <= 1) return n;
        vector<int> dp(n + 1);
        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.爬楼梯

解题思路

1.dp[i]:达到第 i 个台阶有 dp[i] 种方法

2.dp[i] = dp[i - 1] + dp[i - 2]

3.dp[1] = 1; dp[2] = 2

4.从前向后遍历

完整代码:

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if (n <= 1) return n;
        vector<int> dp(n + 1);
        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.使用最小花费爬楼梯

解题思路

1.dp[i]:到达下标 i 位置所需的最小 花费为dp[i]

2.dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2])

3.dp[0] = 0; dp[1] = 0

4.从前向后

完整代码:

cpp 复制代码
class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        int n = cost.size();
        if (n <= 1) return cost[n];
        vector<int> dp(n + 1);
        dp[0] = 0;
        dp[1] = 0;
        for (int i = 2; i <= n; i ++) {
            dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);
        }
        return dp[n];
    }
};
相关推荐
tao35566715 分钟前
【Python刷力扣hot100】42. Trapping Rain Water
开发语言·python·leetcode
Miraitowa_cheems21 分钟前
LeetCode算法日记 - Day 88: 环绕字符串中唯一的子字符串
java·数据结构·算法·leetcode·深度优先·动态规划
B站_计算机毕业设计之家1 小时前
python电商商品评论数据分析可视化系统 爬虫 数据采集 Flask框架 NLP情感分析 LDA主题分析 Bayes评论分类(源码) ✅
大数据·hadoop·爬虫·python·算法·数据分析·1024程序员节
小白菜又菜2 小时前
Leetcode 1518. Water Bottles
算法·leetcode·职场和发展
长存祈月心2 小时前
Rust Option 与 Result深度解析
算法
杭州杭州杭州2 小时前
机器学习(3)---线性算法,决策树,神经网络,支持向量机
算法·决策树·机器学习
星竹晨L3 小时前
C++继承机制:面向对象编程的基石
开发语言·c++
9ilk4 小时前
【仿RabbitMQ的发布订阅式消息队列】--- 模块设计与划分
c++·笔记·分布式·后端·中间件·rabbitmq
不语n4 小时前
快速排序(Quick Sort)详解与图解
数据结构·算法·排序算法·快速排序·双指针排序
三萬Q4 小时前
数据结构--并查集
数据结构