代码随想录算法训练营第四十一天 | 理论基础、509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯

理论基础

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

动归五部曲

1.dp数组以及下标的含义

2.递推公式

3.dp数组如何初始化

4.遍历顺序(例如先背包再物品,先物品再背包)

5.打印dp数组

509. 斐波那契数

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

解题思路

1.确定dp[i]含义, dp[i]表示第i个斐波那契数的值

2.递推公式,dp[i] = dp[i-1] + dp[i-2]

3.dp数组如何初始化 dp[0] = 1 , dp[1] = 1

4.确定遍历顺序,从前往后

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

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

解题思路

到几阶,之前需要看前两阶的方法,第前2阶垮两步即可,第前1阶垮一步即可,所以就是前两阶的方法种数相加

1.dp[i] 达到第i阶楼梯有dp[i]种方法

  1. 根据分析 dp[i] = dp[i-1] + dp[i-2]

3.初始化 d[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. 使用最小花费爬楼梯

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

解题思路

1.dp[i] 表示到达第i个台阶所消耗的最少体力

  1. dp[i]可以由dp[i-1]+ cost[i-1]和dp[i-2] + cost[i-2]得到,取最小值即可

3.初始化选择初始台阶时,不需要花费体力,只有跳才会花费,因此dp0和1都是0

4.遍历顺序:从前往后,因为都是由前面的台阶跳上来的

cpp 复制代码
class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        int n = cost.size();
         vector<int> dp(n+1);
         dp[0] = 0;
         dp[1] = 0;  //选择下标1或者0作为起始,没有体力花费,只有跳了才有花费
         for(int i=2 ; i < n+1 ; i++)
         {
            dp[i] = min( dp[i-1] + cost[i-1], dp[i-2] + cost[i-2]);
         }
         return dp[n];
    }
};

收获

终于开始动规了,加油

相关推荐
liang_202611 分钟前
【HT周赛】T3.二维平面 题解(分块:矩形chkmax,求矩形和)
数据结构·笔记·学习·算法·平面·总结
緈福的街口13 分钟前
【leetcode】2900. 最长相邻不相等子序列 I
算法·leetcode·职场和发展
易只轻松熊14 分钟前
C++(20): 文件输入输出库 —— <fstream>
开发语言·c++·算法
远瞻。34 分钟前
【论文阅读】人脸修复(face restoration ) 不同先验代表算法整理
论文阅读·算法
进击的小白菜40 分钟前
LeetCode 153. 寻找旋转排序数组中的最小值:二分查找法详解及高频疑问解析
数据结构·算法·leetcode
dog2501 小时前
BBR 的 buffer 动力学观感
人工智能·算法
冲帕Chompa4 小时前
图论part10 bellman_ford算法
数据结构·算法·图论
緈福的街口4 小时前
【leetcode】144. 二叉树的前序遍历
算法·leetcode
GG不是gg4 小时前
排序算法之基础排序:冒泡,选择,插入排序详解
数据结构·算法·青少年编程·排序算法
随意起个昵称4 小时前
【双指针】供暖器
算法