【LeetCode】每日一题 2023_12_17 使用最小花费爬楼梯(动态规划)

文章目录

刷题前唠嗑

考完六级,我终于又回来了,LeetCode 每日一题?启动!!!

题目:使用最小花费爬楼梯

题目链接:746. 使用最小花费爬楼梯

题目描述

代码与解题思路

go 复制代码
func minCostClimbingStairs(cost []int) int {
    dp := make([]int, len(cost)+1)
    for i := 2; i <= len(cost); i++ {
        dp[i] = min(dp[i-1]+cost[i-1], dp[i-2]+cost[i-2])
    }
    return dp[len(cost)]
}

我之前在学动态规划的时候刷过这道题目,这是一道比较经典的动态规划简单题,爬楼梯系列的一道变种题目,动归的固定步骤:

  1. 推出状态转移方程,这一步最重要,也是最难的一步
  2. 初始化 dp 数组
  3. 填写 dp 数组
  4. 返回

这道题状态转移方程怎么推出来呢?根据题目可知,走到 dp[ i ] 有两种情况:

  1. 走了一步,那就是 i - 1 级阶梯积累的花费加上 i - 1 级阶梯需要的花费,也就是 dp[ i - 1 ] + cost[ i - 1 ]
  2. 走了两步,那就是 i - 2 级阶梯积累的花费加上 i - 2 级阶梯需要的花费,也就是 dp[ i - 2 ] + cost[ i - 2 ]
  3. 而我们要求的是最小的花费,所以取他俩的最小值

这样我们就能推出状态转移方程是:min(dp[ i - 1 ] + cost[ i - 1 ],dp[ i - 2 ] + cost[ i - 2 ])

相关推荐
Kk.080220 分钟前
项目《基于Linux下的mybash命令解释器》(一)
前端·javascript·算法
SteveSenna39 分钟前
Trossen Arm MuJoCo自定义1:改变目标物体
人工智能·学习·算法·机器人
yong99901 小时前
IHAOAVOA:天鹰优化算法与非洲秃鹫优化算法的混合算法(Matlab实现)
开发语言·算法·matlab
米粒12 小时前
力扣算法刷题 Day 42(股票问题总结)
算法·leetcode·职场和发展
浅念-4 小时前
从LeetCode入门位运算:常见技巧与实战题目全解析
数据结构·数据库·c++·笔记·算法·leetcode·牛客
CoovallyAIHub4 小时前
无人机拍叶片→AI找缺陷:CEA-DETR改进RT-DETR做风电叶片表面缺陷检测,mAP50达89.4%
算法·架构·github
田梓燊4 小时前
leetcode 142
android·java·leetcode
CoovallyAIHub4 小时前
混合训练反而更差?VLM Agent在训练前协调跨数据集标注,文档布局检测F-score从0.860提升至0.883
算法·架构·github
鸿途优学-UU教育4 小时前
教材质量——法考培训的根基与底气
算法
_深海凉_4 小时前
LeetCode热题100-最大数(179)
算法·leetcode·职场和发展