452,跳跃游戏
myzbx 2025-05-24 15:43 2 浏览
给定一个非负整数数组,你最初位于数组的第一个位置。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个位置。
示例 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,否则就在当前位置所能到达最大位置前的元素都要遍历一遍,然后记录下他能跳的最大距离。
相关推荐
- 一步一步往上爬 可爱像素跳跃《Cuby Jump》
-
CliqersSdnBhd宣布旗下新作《CubyJump》已经正式在全球的iOS及Android双平台上架。该作是一款像素风格的跳跃游戏,玩家要控制萌萌哒的各种角色跃过险阻到达顶峰。玩家必须操控...
- Apex英雄手游版上手实测:“味对了”,但瑜不掩瑕
-
大家好呀,这里是你们的小编。《Apex英雄》近日在菲律宾开启了小范围Beta测试。小编也是费尽心思,终于能够上手体验这款《Apex英雄》的手游版啦!先给出一个结论:有端游的感觉,但是还不够。《Apex...
- 《古墓丽影崛起》高空滑索怎么转换?高空滑索技巧分享
-
在《古墓丽影崛起》中,要完成高空滑索转换并解锁“滑索专家”奖杯,玩家需要掌握一定的技巧和时机。以下是一些具体的步骤和建议:一、高空滑索转换技巧芭芭雅嘎打女巫场景:在游戏中,芭芭雅嘎打女巫的场景是完成高...
- 第一人称跑酷游戏FOTONICA:急速奔跑的超快感
-
一款第一人称跑酷游戏,3年前已登陆PC端,以其绝妙的几何抽象艺术画面吸引了玩家们的目光。今夏登陆iOS平台,在原版的基础上增加了新的曲目和关卡,光怪陆离的跑酷场景不断刺激你的双眼。想玩好,首先要有...
- 点击类休闲游戏《跳转战士》 在跳跃中寻求厮杀快感
-
寿司发表于2015-12-2417:52以不断砍杀怪物从而获得经验和奖励的游戏可谓十分常见,不过近日推出的这款休闲游戏JumpWarrior《跳转战士》却采用了不断跳跃的方式来进行游玩。在这款...
- FC游戏《冒险岛》1234通关结局赏析,多少玩家被卡了整整三十年
-
《冒险岛》系列应该是所有玩家们的共同回忆吧!就是不知道当年的你接触过哪一代呢?《冒险岛》在红白机平台发行了四部作品,在街机平台有一款名为《神奇小子》的游戏和《冒险岛》很有渊源,这在之前我们已经仔细研究...
- 452,跳跃游戏
-
给定一个非负整数数组,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达最后一个位置。示例1:输入:[2,3,1,1,4]输出:true解释:我们...
- 休闲游戏《跳跃山羊》:简单跳跃填色带你回温经典
-
Laficko发表于2015-12-0515:33经典街机游戏《Q伯特》凭借着颇具立体感的画面效果以及简单的填色玩法,在过去80年代便受到不少玩家的喜爱。如今开发商ATOOI按照这款经典...
- 游戏百解——跳一跳(Python自动跳跃)
-
跳一跳Python游戏百解。今天将教大家怎么用Python程序做一个跳一跳这个游戏的辅助工具,在后续将加入图像识别算法,让小人可以自动识别并跳到下个平台。·首先得确定两个平台之间的距离,做了一个简单的...
- 《幻塔》战斗体系解析:浮空闪避,动作体验如何丝滑?
-
前言相较于武侠、仙侠、魔幻题材而言,提起科幻类型的游戏,大部分人都会在脑海里浮现出“硬核”、“烧脑”等一系列足以劝退萌新小白的形容词。正因如此,怎样深入浅出地讲好一个科幻故事,探讨科技与人性的关系,也...
- 《电精》和《电神魔傀》的无敌隐身,街机游戏中的上帝模式
-
估计很多玩家都还分不清楚《电精》和《电神魔傀》这两款游戏吧!简单一点来说的话,《电精》就是三人版,来自SFC平台。而《电神魔傀》则是六人版,来自街机平台。当年我们在街机游戏厅中玩到的几乎都是《电精》,...
- 3D平台跳跃游戏《蓝精灵:梦境》发布首支预告:2024年底推出
-
IT之家4月29日消息,发行商Microids今日发布了3D平台跳跃游戏《蓝精灵:梦境》的首支预告。目前游戏Steam商店页面已经上线,游戏支持单人游玩,或与一名好友组队双人游玩...
- 黏液 - 评测:小巧有趣的平台跳跃冒险游戏
-
与自家的整洁程度有所不同,我反倒发现在游戏中完成清洁工作有种莫名的满足感。正因如此,《黏液(TheGunk)》对我来说有着别样的吸引力,因为它的线性战役为我提供了这样的机会,将一个被黏液覆盖的外星球...
- 魔兽怀旧服:熊坦跳跃的时候无躲闪?深入研究6条原理,涨知识了
-
一位魔兽世界TBC怀旧服的熊坦玩家在打团的时候被队友吐槽了,队友认为他的游戏习惯不好,经常跳跃导致滞空时间过长会没有躲闪。这个队友的建议让熊坦一脸懵,跳跃无躲闪这个说法他还是第一次听到,那么这位队友的...
- “趣游戏”唤醒两代人的童年!课间15分钟已悄然升级到“PLUS版本”
-
为了响应省教育厅“2·15”专项行动的要求,新学期开学以来,南京江北新区高新实验小学的课间延长到了15分钟。如何让延长的课间既安全有序又充满活力?该校开展了校园达人“封绳榜”挑战赛,用一根小小的跳绳,...
- 一周热门
- 最近发表
- 标签列表
-
- 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 选择器 (30)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)