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

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. 初始条件:起点前的位置无需花费。

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

http://www.xdnf.cn/news/6584.html

相关文章:

  • java -jar命令运行 jar包时如何运行外部依赖jar包
  • IEEE 列表会议第五届机器人、自动化与智能控制国际会议
  • python怎么将函数设置为保护状态
  • Suna: 开源多面手 AI 代理
  • MySQL数据库——支持远程IP访问的设置方法总结
  • LLM学习笔记(六)线性代数
  • 04、基础入门-SpringBoot官方文档架构
  • 代理(主要是动态)和SpringAOP
  • Hue面试内容整理-Hue 架构与前后端通信
  • pytorch 14.3 Batch Normalization综合调参实践
  • SearxNG本地搜索引擎
  • Java并发编程核心组件简单了解
  • 日志与策略模式
  • 正向代理和反向代理的区别?
  • LabVIEW图像粒子处理
  • 【LeetCode 热题 100】5. 最长回文子串(Python中心扩展法详解)
  • IOP出版|第二届人工智能、光电子学与光学技术国际研讨会(AIOT2025)
  • CCIE与HCIE哪个考试难度更大?
  • 如何将数据从一部手机传输到另一部手机 | 5 种便捷传输方式
  • 无人机减震模块运行与技术要点分析!
  • 关于 TCP 端口 445 的用途以及如何在 Windows 10 或 11 上禁用它
  • 深入 Linux 内核:GPU Runtime Suspend 源码和工作流程全面分析
  • 若依框架Consul微服务版本
  • [原创](计算机数学): 生日概率问题.
  • 电子电器架构 --- Zonal架构正在开创汽车电子设计新时代
  • 小刚说C语言刷题—1700请输出所有的2位数中,含有数字2的整数
  • 天能股份SAP系统整合实战:如何用8个月实现零业务中断的集团化管理升级
  • 升级kafka4.0.0,无ZK版本
  • android 安装openwrt 安正步骤
  • Android trace中CPU的RenderThread与GPU