452,跳跃游戏
myzbx 2025-05-24 15:43 33 浏览
给定一个非负整数数组,你最初位于数组的第一个位置。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个位置。
示例 1:
输入: [2,3,1,1,4]
输出: true
解释: 我们可以先跳 1 步,从位置 0 到达位置 1, 然后再从位置 1 跳 3 步到达最后一个位置。
示例 2:
输入: [3,2,1,0,4]
输出: false
解释: 无论怎样,你总会到达索引为 3 的位置。但该位置的最大跳跃长度是 0 , 所以你永远不可能到达最后一个位置。
保存每步所能到达的最大距离
这题让求的是能否到达最后一个位置,我们先遍历数组的数字,然后保存下来他所能跳到的最大距离,如果能到达最后一个位置,直接返回true,如果不能到达就继续遍历,如果最大距离连下一步都到不了,就直接返回false。
比如第一步能跳到的最大距离是3,也就是说接下来的3个位置都是可以到达的,我们就要遍历接下来的3个位置,并记录这3个位置所能到达的最大距离,如果这3个位置的任何一个位置的最大距离能到达最后一个位置,直接返回true。
以示例2为例画个图来看下,第1个元素的值是3,所以接下来的3个位置都能到达,因为前3个位置所能跳到的最大距离是第4个位置,然后到第4个位置的时候,他能跳到的最大距离是0,不能到下一步了,直接返回false。
public boolean canJump(int[] nums) {
//maxStep表示能到达的距离
int maxStep = 0;
int length = nums.length;
for (int i = 0; i < length; i++) {
//如果跳不到位置i,直接返回false
if (i > maxStep)
return false;
//如果能跳到位置i,就更新所能跳的最大距离
maxStep = Math.max(maxStep, i + nums[i]);
//如果能跳到最后的位置,说明能够成功,直接终止循环
if (maxStep >= length)
return true;
}
return true;
}
从后往前判断
可以逆向思维,这题说的是从前往后跳的,我们也可以从后往前来推断,从数组的最后第二位开始计算,如果当前的位置加上当前所能跳转的最大距离大于等于last,说明这一步跳转是没问题的,是可以到达last这一步(last初值是数组的最后一个元素)。能走到第一步,即last等于0的时候,说明是可以从位置0跳到最后一位的。
public boolean canJump(int[] nums) {
//last表示的是能不能到达last这个位置
int last = nums.length - 1;
for (int i = nums.length - 2; i >= 0; i--) {
//从倒数第2个位置往前遍历,如果当前位置能够跳
//到last这个位置,就更新last,如果从当前位置
//不能到达last这个位置就继续往前遍历
if (i + nums[i] >= last)
last = i;
}
//如果last等于0,说明可以从第一个位置跳到最后
return last == 0;
}
总结
这题没有什么难度,第2种方式不太容易想到,一般更容易想到的是第一种解决方式,就是每走一步都要判断所能跳的最大距离,如果能够到达最后就直接返回,如果连下一步都到不了,那么就不可能到达最后了,直接返回false,否则就在当前位置所能到达最大位置前的元素都要遍历一遍,然后记录下他能跳的最大距离。
相关推荐
- 男人的内裤,到底可以穿多久?(男人内裤最多能穿几天)
-
女生们如果家里有男生可能会发现——他们对内裤很恋旧穿到褪色松垮穿到别有洞天穿到一网情深穿到人间蒸发都仍然...舍不得这位老伙计男生们到底有多热爱旧内裤?有外国媒体曾在街头采访,发现:女士们往往会随...
- typeof 与 instanceof 区别(typeof与instanceof区别)
-
typeof操作符返回一个字符串,表示未经计算的操作数的类型使用方法如下:typeofoperandtypeof(operand)operand表示对象或原始值的表达式,其类型将被返回举个例子...
- 年纪轻轻病情就已是晚期!你还敢再喝这种饮料吗?
-
本文作者:谢祥成,浙江大学医学院附属邵逸夫医院肾内科主任医师吴俊男,浙江大学医学院附属邵逸夫医院肾内科主治医师30岁的金先生(化名)是一名才华横溢的设计师。半年前出现视物模糊,起初以为是用眼过度,没有...
- typeof 与 instanceof 有什么区别
-
typeof和instanceof是JavaScript中用于类型检查的两个操作符,但它们的用途和适用场景有显著区别。以下是它们的区别及使用注意事项:1.typeof作用:返回一个变量的基本...
- 数据结构之顺序表(数据结构顺序表图书管理系统)
-
线性表定义线性表是n(n≥0)个具有相同特性的数据元素的有限序列。记作:(a1,a2,…,ai-1,ai,ai+1,…,an)线性表相关概念直接前驱元素:ai-1领先于ai,称a...
- 每一个成熟的人,都需要具备「翻篇」这种能力
-
“翻篇儿”——仿佛读出这个儿化音,才够表达那种潇洒的感觉是一种人生中非常重要的心理过程和心理技能。人生注定不完美,我们只要活着就会遭遇不愉快的经历,只有及时翻篇儿,才能把更多注意力放在当下,不被过去的...
- 打通 JAVA 与内核系列之 一 ReentrantLock 锁的实现原理
-
写JAVA代码的同学都知道,JAVA里的锁有两大类,一类是synchronized锁,一类是concurrent包里的锁(JUC锁)。其中synchronized锁是JAVA语言层面提供的能力,在此不...
- 韩国吃货主播,美食声控咀嚼音,你是搬运工,好吃到停不下来
-
刘姐畅谈。Hey,Hongsi。TodaywehaveassortedtoysthatImade。Foryouguysfirst。Itlookscrunchybecause...
- 黄子韬2019新歌最好的我们完整歌词介绍在哪可以听
-
最好的我们(TheBestofUs)-黄子韬词:黄子韬曲:黄子韬编曲:DarylK制作人:DarylK助理制作:郭舒文和音:黄子韬电吉他:CalvinC木吉他:雷十一录音室:Kong...
- 刷一道LeetCode -- 三数之和(三数之和算法)
-
原题:https://leetcode-cn.com/problems/3sum/给你一个包含n个整数的数组nums,判断nums中是否存在三个元素a,b,c,使得a+b+c...
- 隐藏在阳光当中的地球刺客(隐藏在阳光下的秘密)
-
小行星什么时候会撞击地球?这一直是大家比较关注的问题,特别是当大家知道地球上前一任住户是亡于小行星之后,就更加关注这个问题了。图1尤卡坦半岛的陨石坑(NASA)实际上,地球每天都会遭受到一些天体的袭...
- 安卓手机爱奇艺app中离线视频导出
-
安卓手机爱奇艺app中离线视频导出:通常我在爱奇艺中发现好的视频,想保存下来,点击离线缓存,缓存好后,在手机上可以查看,但是使用手机连接电脑打开后,发现保存视频的文件夹是空的。1)在手机中爱奇艺文...
- 50款经典奥斯汀月季,超多图片,抗病好养新手必种的月季
-
【50款经典奥斯汀月季】大家好,今天来给大家介绍50款经典的奥斯汀月季,奥斯汀是一位伟大的育种家,以他命名的奥斯汀公司也繁育出了数量众多的月季品种。根据木木的种植经验,奥斯汀的月季大多植株长势良...
- 你也想像J姐一样在梦幻芭比大house里“哭泣”吗?
-
“6年前我的兜里只揣着400元美金,现如今我已经住上了这上亿豪宅”他是一个我行我素,敢说敢做的一个网红博主他测评过的彩妆都卖断货了他的自创同名品牌深受好评他就是JeffreeStar,你们传说中的J...
- VB Do While\Until,Loop循环语句
-
DoWhile\Until…….Loop循环语句上一节讲了For……Next循环语句,这节讲DoWhile\Until…….Loop循环语句。有人会有疑问,既然有For循环,还要Do循环干什么?它...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)
- JS Loop For (32)