博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode算法题-Min Cost Climbing Stairs(Java实现)
阅读量:7280 次
发布时间:2019-06-30

本文共 1204 字,大约阅读时间需要 4 分钟。

这是悦乐书的第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

03 第二种解法

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

public int minCostClimbingStairs(int[] cost) {    int prev = 0, prev2 = 0, current = 0;    for(int i = 2; i

04 小结

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

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

转载于:https://www.cnblogs.com/xiaochuan94/p/10714755.html

你可能感兴趣的文章
三步解决EntityFramework Code First中的MissingMethodException错误
查看>>
关于在UITableViewController页面添加UINavigationBar的方法
查看>>
php --with-mysql=mysqlnd
查看>>
登录(ajax提交数据和后台校验)
查看>>
谷歌中国的第一款产品“猜画小歌”
查看>>
HTTP 错误 500.19 - Internal Server Error
查看>>
序列起始值修改
查看>>
蓝点中文_Linux2.0 实验三 用户组管理
查看>>
php表单在提交之后再后退,表单的内容默认是被清空的
查看>>
重写方法Android中的HttpsURLConnection连接
查看>>
linux(ubuntu) 查看系统设备信息
查看>>
hdu4467 Graph
查看>>
C#中byte类型转换为double类型
查看>>
有意思的网站
查看>>
max3232
查看>>
linux读写ntfs
查看>>
x264 编码器选项分析 (x264 Codec Strong and Weak Points) 1
查看>>
lintcode:带环链表
查看>>
10最好的开放源移动工具的工作场所
查看>>
【转载】为什么不建议<=3G的情况下使用CMS GC
查看>>