LeetCode算法题-Min Cost Climbing Stairs(Java实现)

时间:2022-02-15 00:29:42

这是悦乐书的第307次更新,第327篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第176题(顺位题号是746)。在楼梯上,第i步有一些非负成本成本[i]分配(0索引)。一旦支付了费用,您可以爬一到两步。您需要找到到达楼层顶部的最低成本,您可以从索引为0的步骤开始,也可以从索引为1的步骤开始。例如:

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

输出:15

说明:最便宜的是从成本[1]开始,支付该成本并返回顶部。



输入:cost= [1,100,1,1,1,100,1,1,100,1]

输出:6

说明:最便宜的是从成本[0]开始,并且仅在1上跳,跳过成本[3]。



注意

  • 成本数组的长度在[2,1000]范围内。

  • 每个成本[i]将是[0,999]范围内的整数。

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

题目的意思是在成本数组中找出成本总和最小的组合,遍历完数组,遍历时可以跨一个单位或两个单位,和之前的爬楼梯的题目有点类似。我们可以推敲一下,如果要爬到第i级楼梯,有两种选择,一是从第i-1级爬上来,二是从第i-2级阶梯爬上来,然后取其中两者的成本值,哪个花费小,就选哪个。对此我们新建一个数组dp,来存储前面每次选择后要花费的成本之和。

因此,我们可以得出一个关系:dp[i] = Math.min(之前爬两次的花费+当前此次是爬两步的花费, 之前爬一次的花费+当前此次是爬一步的花费);依次计算取其中的较小值存入dp中即可,最后返回dp的最后一位元素。

public int minCostClimbingStairs(int[] cost) {
int[] dp = new int[cost.length+1];
for (int i=2; i<cost.length+1; i++) {
dp[i] = Math.min(dp[i-2]+cost[i-2], dp[i-1]+cost[i-1]);
}
return dp[dp.length-1];
}

03 第二种解法

我们还可以对上面的解法进行优化,不使用数组单独存每一次的计算结果,因为新的计算只是依赖前两次的结果,所以我们使用了两个临时变量来存储前两次的计算值,思路和上面第一种解法还是一样的。

public int minCostClimbingStairs(int[] cost) {
int prev = 0, prev2 = 0, current = 0;
for(int i = 2; i<cost.length+1; i++){
current = Math.min(cost[i-2]+prev2, cost[i-1]+prev);
prev2 = prev;
prev = current;
}
return current;
}

04 小结

算法专题目前已日更超过五个月,算法题文章176+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode算法题-Min Cost Climbing Stairs(Java实现)的更多相关文章

  1. 【Leetcode】746&period; Min Cost Climbing Stairs

    题目地址: https://leetcode.com/problems/min-cost-climbing-stairs/description/ 解题思路: 官方给出的做法是倒着来,其实正着来也可以 ...

  2. 【LeetCode】746&period; Min Cost Climbing Stairs 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 动态规划 日期 题目地址:https://leetc ...

  3. LeetCode 746&period; 使用最小花费爬楼梯&lpar;Min Cost Climbing Stairs&rpar; 11

    746. 使用最小花费爬楼梯 746. Min Cost Climbing Stairs 题目描述 数组的每个索引做为一个阶梯,第 i 个阶梯对应着一个非负数的体力花费值 cost[i].(索引从 0 ...

  4. Min Cost Climbing Stairs - LeetCode

    目录 题目链接 注意点 解法 小结 题目链接 Min Cost Climbing Stairs - LeetCode 注意点 注意边界条件 解法 解法一:这道题也是一道dp题.dp[i]表示爬到第i层 ...

  5. Leetcode之动态规划(DP)专题-746&period; 使用最小花费爬楼梯(Min Cost Climbing Stairs)

    Leetcode之动态规划(DP)专题-746. 使用最小花费爬楼梯(Min Cost Climbing Stairs) 数组的每个索引做为一个阶梯,第 i个阶梯对应着一个非负数的体力花费值 cost ...

  6. leetcode 746&period; Min Cost Climbing Stairs&lpar;easy understanding dp solution&rpar;

    leetcode 746. Min Cost Climbing Stairs(easy understanding dp solution) On a staircase, the i-th step ...

  7. LN &colon; leetcode 746 Min Cost Climbing Stairs

    lc 746 Min Cost Climbing Stairs 746 Min Cost Climbing Stairs On a staircase, the i-th step has some ...

  8. 746&period; Min Cost Climbing Stairs&commat;python

    On a staircase, the i-th step has some non-negative cost cost[i] assigned (0 indexed). Once you pay ...

  9. 【Leetcode&lowbar;easy】746&period; Min Cost Climbing Stairs

    problem 746. Min Cost Climbing Stairs 题意: solution1:动态规划: 定义一个一维的dp数组,其中dp[i]表示爬到第i层的最小cost,然后来想dp[i ...

随机推荐

  1. C&sol;C&plus;&plus;中如何获取数组的长度&quest;

    C.C++中没有提供 直接获取数组长度的函数,对于存放字符串的字符数组提供了一个strlen函数获取长度,那么对于其他类型的数组如何获取他们的长度呢?其中一种方法是使 用sizeof(array) / ...

  2. WordPress页面函数功能代码调用大全

    WordPress模板基本文件 style.css 样式表文件index.php 主页文件single.php 日志单页文件page.php 页面文件archvie.php 分类和日期存档页文件sea ...

  3. &lbrack;bzoj1273&rsqb; &lbrack;BeiJingWc2008&rsqb;序列

    一开始想拆位..但显然没法应对进位啊什么的. 所以维护每一个长度的后缀. 查询有多少个a&2^i>0,也就是长度为(i+1)的后缀里,值为2^i...2^(i+1)-1的数有多少个. 前 ...

  4. spring boot 文件上传 文件过大 FileUploadBase&dollar;SizeLimitExceed

    application.properties中加入 multipart.maxFileSizemultipart.maxRequestSize Spring Boot 1.3.x或者之前 multip ...

  5. python3全栈开发-内置函数补充,反射,元类,&lowbar;&lowbar;str&lowbar;&lowbar;&comma;&lowbar;&lowbar;del&lowbar;&lowbar;&comma;exec&comma;type&comma;&lowbar;&lowbar;call&lowbar;&lowbar;方法

    一.内置函数补充 1.isinstance(obj,cls)检查是否obj是否是类 cls 的对象 class Foo(object): pass obj = Foo() print(isinstan ...

  6. 如何利用pip自动生成和安装requirements&period;txt依赖

    在查看别人的Python项目时,经常会看到一个requirements.txt文件,里面记录了当前程序的所有依赖包及其精确版本号.这个文件有点类似与Rails的Gemfile.其作用是用来在另一台PC ...

  7. 【Mysql sql inject】POST方法BASE64编码注入write-up

      翻到群里的小伙伴发出一道POST型SQL注入题,简单抓包判断出题目需要base64编码后才执行sql语句,为学习下SQL注入出题与闯关的思路+工作不是很忙,所以花点时间玩了一下,哈哈哈哈哈哈哈哈哈 ...

  8. 2018&period;10&period;13 bzoj1834&colon; &lbrack;ZJOI2010&rsqb;network 网络扩容(最大流&plus;费用流)

    传送门 网络流水题啊. 第一问直接放心跑最大流(本来还以为有什么tricktricktrick). 第二问就直接把原来的边(u,v,c,w)(u,v,c,w)(u,v,c,w)变成(u,v,c,0)( ...

  9. MySQL对结果进行排序order by

    order by {col_name | expr | position} [ASC | DESC] 查询结果     排序条件的顺序  决定   排序条件   的优先级 如果同一条件下值相等,那么启 ...

  10. 通过DG&lowbar;BROKE搭建Oracle11g&lowbar;adg

    1.环境 db_primary db_stanby db版本 11.2.0.4.0 11.2.0.4.0 os版本 centos 6.4 centos 6.4 db_unique_name newte ...