当前位置: 首页 > news >正文

LeetCode 746 使用最小花费爬楼梯

当然可以!LeetCode 746 是一道经典的动态规划入门题,我来用 C++ 为你详细解释。

题目描述

给定一个整数数组 cost,其中每个元素 cost[i] 表示从第 i 个台阶向上爬需要支付的费用。一旦支付费用,你可以选择向上爬 1 步2 步
你可以从下标 01 的台阶开始爬。
目标:计算到达楼梯顶部(即最后一个台阶之后)的最小总花费。

核心思路

  1. 动态规划定义
    dp[i] 表示到达第 i 个台阶所需的最小总花费。
    最终答案dp[n],其中 n = cost.size()(即到达顶部的最小花费)。

  2. 状态转移方程
    到达第 i 个台阶的方式有两种:

    • 从第 i-1 个台阶爬一步,总花费为 dp[i-1] + cost[i-1]
    • 从第 i-2 个台阶爬两步,总花费为 dp[i-2] + cost[i-2]
      因此:
    dp[i] = min(dp[i-1] + cost[i-1], dp[i-2] + cost[i-2])
    
  3. 初始条件

    • dp[0] = 0:无需花费即可站在起点前。
    • dp[1] = 0:同理,可选择从下标 0 或 1 开始,无需初始花费。

C++ 代码实现

#include <vector>
#include <algorithm>
using namespace std;class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int n = cost.size();if (n == 0) return 0;vector<int> dp(n + 1, 0);  // dp[i] 表示到达第 i 个台阶的最小花费// 初始化:站在起点前(0 或 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];  // 到达顶部(第 n 个台阶)的最小花费}
};

优化空间复杂度

由于 dp[i] 只依赖于 dp[i-1]dp[i-2],可以用两个变量滚动优化:

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int n = cost.size();if (n == 0) return 0;int prev2 = 0;  // 对应 dp[i-2]int prev1 = 0;  // 对应 dp[i-1]for (int i = 2; i <= n; ++i) {int current = min(prev1 + cost[i-1], prev2 + cost[i-2]);prev2 = prev1;prev1 = current;}return prev1;  // 对应 dp[n]}
};

示例解释

输入:cost = [10, 15, 20]

  • dp[0] = 0
  • dp[1] = 0
  • dp[2] = min(dp[1] + 15, dp[0] + 10) = min(0 + 15, 0 + 10) = 10
  • dp[3] = min(dp[2] + 20, dp[1] + 15) = min(10 + 20, 0 + 15) = 15
    输出:15(从下标 1 开始,支付 15,直接跳两步到顶部)

关键点总结

  1. 动态规划思想:用 dp 数组记录到达每个台阶的最小花费。
  2. 状态转移:当前状态只依赖前两个状态,可用滚动数组优化空间。
  3. 初始条件:起点前的位置无需花费。

这类问题是动态规划的基础,掌握后可轻松解决更复杂的路径优化问题!

相关文章:

  • matlab求解问题
  • Java注解详解:从入门到实战应用篇
  • Redisson分布式锁-锁的可重入、可重试、WatchDog超时续约、multLock联锁(一文全讲透,超详细!!!)
  • Qt窗口中消除边框的解决方法
  • HarmonyOS 开发之 —— 合理使用动画与转场
  • 【第七节】ESP32-S3 霍尔传感器应用实战:磁场检测与蜂鸣器控制
  • 消息扩散--tarjan缩点
  • 反转链表链表数据结构oj题(206)
  • 【未完】【GNN笔记】EvolveGCN:Evolving Graph Convolutional Networks for Dynamics Graphs
  • 测试:TestCafe - 判断按钮是否活性化
  • 【Elasticsearch】flattened`类型在查询嵌套数组时可能返回不准确结果的情况
  • 电子电路仿真实验教学平台重磅上线!——深圳航天科技创新研究院倾力打造,助力高校教学数字化转型
  • 产品经理如何做好需求管理
  • 国产三维CAD皇冠CAD(CrownCAD)建模教程:插接箱
  • 安科瑞AcrelEMS3.0企业微电网智慧能源平台-安科瑞 蒋静
  • ZYNQ Overlay硬件库使用指南:用Python玩转FPGA加速
  • OpenCV 级联分类器目标检测
  • 第五部分:第五节 - Express 路由与中间件进阶:厨房的分工与异常处理
  • Linux 系统切换国内镜像源教程
  • 2025年上软考 考试时间+准考证打印全攻略
  • 麻涌做网站/谷歌怎么投放广告
  • 美康优选网站怎么做的/网页模版
  • 深圳专业做网站建网站价格/百度推广效果不好怎么办
  • 波波网站建设/刷赞抖音推广网站
  • 网站被百度删除的原因/seo推广培训课程
  • 淘宝联盟建网站/长沙百度快速排名