news 2026/4/18 0:54:01

可视化图解算法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进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 0:08:15

大模型/人工智能高薪职位全解析,助你规划技术发展之路

本文是一份AI大模型领域的高薪职位招聘汇总&#xff0c;包含AI大模型架构师、性能优化专家、算法专家等多个职位&#xff0c;遍布全国主要城市&#xff0c;薪资普遍在80-300W。这些职位要求应聘者具备深厚的机器学习、深度学习理论基础&#xff0c;熟悉大模型架构和训练优化技术…

作者头像 李华
网站建设 2026/4/12 15:55:05

Flutter 开发的鸿蒙AtomGit OAuth 授权应用

Flutter 开发的鸿蒙AtomGit OAuth 授权应用 项目概述 这是一个基于 Flutter 开发的鸿蒙OAuth 2.0 授权应用&#xff0c;用于获取 AtomGit 授权用户的个人信息。应用实现了完整的 OAuth 授权流程&#xff0c;包括&#xff1a; ✅ OAuth 2.0 授权码模式✅ 访问令牌获取和刷新✅…

作者头像 李华
网站建设 2026/4/17 14:39:13

爬虫党干货 | 构建一个高成功率的访问环境一定要知道这些!

当爬虫并发量上升、请求规模扩大&#xff0c;原本 “能抓到数据” 的代码开始频繁出现请求失败、连接超时、IP 封禁等问题时&#xff0c;说明你需要突破的不再是代码技巧&#xff0c;而是访问环境的稳定性设计能力。你或许早已熟练运用 requests、Scrapy、Playwright&#xff0…

作者头像 李华
网站建设 2026/4/14 18:57:55

基于Facet核方法和随机游走的红外小目标检测MATLAB实现

M00109-基于Facet核方法和随机游走的红外小目标检测MATLAB实现 在红外搜索和跟踪&#xff08;IRST&#xff09;应用中&#xff0c;高效地探测信噪比&#xff08;SCR&#xff09;低的复杂背景下的目标非常重要。 从局部图像分割角度解决目标检测问题&#xff0c;提出了一种新的小…

作者头像 李华
网站建设 2026/4/17 20:43:39

django基于python的大学生心理咨询系统的设计与开发_e8pz475y

文章目录系统截图项目技术简介可行性分析主要运用技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;系统截图 djangopython_e8pz475y 的大学生心理咨询系统的设计与开发基于 项目技术简介 Python版本&…

作者头像 李华
网站建设 2026/4/17 20:06:49

django基于Python的学生宿舍管理系统的设计与实现 可视化2c0svsyf

文章目录系统截图项目技术简介可行性分析主要运用技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;系统截图 DjangoPython可视化2csvsyf 的学生宿舍管理系统的设计与实现基于 项目技术简介 Python版本&…

作者头像 李华