news 2025/12/31 22:11:20

可视化图解算法74:最小花费爬楼梯

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
可视化图解算法74:最小花费爬楼梯

1.题目

描述

给定一个整数数组 cost ,其中 cost[i]是从楼梯第i 个台阶向上爬需要支付的费用,下标从0开始。一旦你支付此费用,即可选择向上爬一个或者两个台阶。

你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。

请你计算并返回达到楼梯顶部的最低花费。

数据范围:数组长度满足 1≤n≤105 ,数组中的值满足 1 ≤cost~i~≤10^4^

示例1

输入:

[2,5,20]

返回值:

5

说明:

你将从下标为1的台阶开始,支付5 ,向上爬两个台阶,到达楼梯顶部。总花费为5

示例2

输入:

[1,100,1,1,1,90,1,1,80,1]

返回值:

6

说明:

你将从下标为 0 的台阶开始。 1.支付 1 ,向上爬两个台阶,到达下标为 2 的台阶。 2.支付 1 ,向上爬两个台阶,到达下标为 4 的台阶。 3.支付 1 ,向上爬两个台阶,到达下标为 6 的台阶。 4.支付 1 ,向上爬一个台阶,到达下标为 7 的台阶。 5.支付 1 ,向上爬两个台阶,到达下标为 9 的台阶。 6.支付 1 ,向上爬一个台阶,到达楼梯顶部。 总花费为 6 。

2. 题解思路

本题求解的是最小花费,因此需要在两条路径中选取最小的值。解题思路如下:

如果文字描述的不太清楚,你可以参考视频的详细讲解。

  • Python编码:https://www.bilibili.com/cheese/play/ep1375304https://www.bilibili.com/cheese/play/ep1375304

  • Java编码:https://www.bilibili.com/cheese/play/ep1368530https://www.bilibili.com/cheese/play/ep1368530

  • Golang编码:https://www.bilibili.com/cheese/play/ep1368730https://www.bilibili.com/cheese/play/ep1368730

3.编码实现

核心代码如下:

//1.定义状态. i:第i个台阶; dp[i]:到达第i个台阶的最小花费 dp := make([]int, len(cost)+1) //2.初始化边界条件: dp[1] = min(0, cost[0]) // dp[1]=cost[0],到达第1阶的费用(从第0阶上来或者从第1阶就地开始); dp[2] = min(cost[0], cost[1]) //dp[2]=min(cost[0],cost[1]),从下标为 0 或下标为 1 的台阶爬到第2个台阶的费用; //3.确定递推公式: for i := 3; i <= len(cost); i++ { pre1 := dp[i-1] + cost[i-1] //到 i-1个台阶的费用 + 第 i-1 个台阶的费用 pre2 := dp[i-2] + cost[i-2] //到 i-2个台阶的费用 + 第 i-2 个台阶的费用 // 到i个台阶的费用:来自于 i-1、i-2(取最小值) dp[i] = min(pre1, pre2) } return dp[len(cost)] } func min(a, b int) int { if a >= b { return b } return a }

具体完整代码你可以参考下面视频的详细讲解。

  • Python编码:https://www.bilibili.com/cheese/play/ep1375304https://www.bilibili.com/cheese/play/ep1375304

  • Java编码:https://www.bilibili.com/cheese/play/ep1368530https://www.bilibili.com/cheese/play/ep1368530

  • Golang编码:https://www.bilibili.com/cheese/play/ep1368730https://www.bilibili.com/cheese/play/ep1368730

4.总结

本题的关键是确定变量i、dp数组的含义,如果理解了他们的含义,就能推到出递推公式,进而写出代码。

《数据结构与算法》深度精讲课程正式上线啦!7 大核心算法模块全解析:

✅ 链表

✅ 二叉树

✅ 二分查找、排序

✅ 堆、栈、队列

✅ 回溯算法

✅ 哈希算法

✅ 动态规划

无论你是备战笔试面试、提升代码效率,还是突破技术瓶颈,这套课程都将为你构建扎实的算法思维底座。🔥立即加入学习打卡,与千名开发者共同进阶!

  • Python编码实现:https://www.bilibili.com/cheese/play/ss897667807https://www.bilibili.com/cheese/play/ss897667807

  • Java编码实现:https://www.bilibili.com/cheese/play/ss161443488https://www.bilibili.com/cheese/play/ss161443488

  • Golang编码实现:https://www.bilibili.com/cheese/play/ss63997https://www.bilibili.com/cheese/play/ss63997

对于LeetCode数据结构与算法,我们总结了一套【可视化+图解】方法,依据此方法来解决相关问题,算法变得易于理解,写出来的代码可读性高也不容易出错。具体也可以参考视频详细讲解。

今日佳句:知之者不如好之者,好知之者不如乐之者。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/29 1:39:06

扭蛋机小程序:线上扭蛋机模式发展新形势[特殊字符]

扭蛋机小程序&#xff1a;线上扭蛋机模式发展新形势&#x1f4b0;随着互联网的发展&#xff0c;扭蛋机在线上也迎来了发展机遇&#xff0c;扭蛋机与互联网进行融合&#xff0c;通过线上扭蛋机小程序让消费者在手机上进行扭蛋&#xff0c;为消费者带来全新的线上体验。&#x1f…

作者头像 李华
网站建设 2025/12/18 21:18:47

49、Bash编程:模式匹配、命令操作与示例代码详解

Bash编程:模式匹配、命令操作与示例代码详解 1. extglob扩展模式匹配运算符 在使用 shopt -s extglob 时,以下运算符会生效。匹配默认区分大小写,但可以使用 shopt -s nocasematch (bash 3.1+)来改变这一特性,该选项会影响 case 和 [[ 命令。 分组 含义 @( …

作者头像 李华
网站建设 2025/12/18 21:18:39

2、深入探索Bash编程:从基础到实用技巧

深入探索Bash编程:从基础到实用技巧 代码获取与结构 代码可从网站(http://www.bashcookbook.com )下载,下载格式为 .tgz 或 .zip 。代码文件通常位于类似 ./chXX/snippet_name 的路径下,其中 chXX 代表章节, snippet_name 是文件名。 “无用的cat使用”探讨…

作者头像 李华
网站建设 2025/12/18 21:18:37

40、计算机日常维护与管理任务实用指南

计算机日常维护与管理任务实用指南 在计算机使用和管理过程中,我们常常会遇到各种任务和问题。本文将为大家介绍一些常见问题的解决方案,涵盖文件重命名、文档查看、文件解压、会话恢复、会话共享、日志记录以及屏幕清理等方面。 1. 批量重命名文件 在实际操作中,我们可能…

作者头像 李华
网站建设 2025/12/18 21:17:37

Kotaemon重排序模型(Re-Ranker)集成教程

Kotaemon重排序模型集成深度指南 在构建企业级智能问答系统时&#xff0c;一个常见的痛点是&#xff1a;即便使用了强大的大语言模型&#xff08;LLM&#xff09;&#xff0c;系统仍可能给出看似合理却与实际政策或知识不符的回答。这种“幻觉”问题在金融、医疗、人力资源等高…

作者头像 李华
网站建设 2025/12/18 21:10:14

Unity学习笔记(二十)PlayerPrefs(一)

目录 PlayerPrefs是什么 存储原理 读取相关 删除数据 PlayerPrefs数据唯一性 PlayerPrefs是什么 是Unity提供的可以用于存储读取玩家数据的公共类 存储原理 PlayerPrefs的数据存储&#xff0c;类似键值对存储&#xff0c;一个键对应一个值 提供了存储3种数据的方法 &am…

作者头像 李华