代码随想录算法训练营第四十一天 | 理论基础、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];
    }
};

收获

终于开始动规了,加油

相关推荐
柳鲲鹏32 分钟前
RGB转换为NV12,查表式算法
linux·c语言·算法
橘颂TA32 分钟前
【剑斩OFFER】算法的暴力美学——串联所有单词的字串
数据结构·算法·c/c++
Kuo-Teng33 分钟前
LeetCode 73: Set Matrix Zeroes
java·算法·leetcode·职场和发展
mit6.82436 分钟前
[HDiffPatch] 补丁算法 | `patch_decompress_with_cache` | `getStreamClip` | RLE游程编码
c++·算法
程序猿202336 分钟前
Python每日一练---第六天:罗马数字转整数
开发语言·python·算法
葵续浅笑1 小时前
LeetCode - 杨辉三角 / 二叉树的最大深度
java·数据结构·算法·leetcode
qq_479875431 小时前
RVO和移动语义
前端·算法
菜小麒1 小时前
推荐算法的八股文
算法·机器学习·推荐算法
Miraitowa_cheems2 小时前
LeetCode算法日记 - Day 94: 最长的斐波那契子序列的长度
java·数据结构·算法·leetcode·深度优先·动态规划
L_09072 小时前
【Algorithm】Day-11
c++·算法·leetcode