news 2026/4/22 23:47:17

跳 跃 游 戏

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
跳 跃 游 戏

文章目录

  • 一、读题
  • 二、示例讲解
  • 三 、算法思路
  • 四、代码实现:

一、读题

题目来源:https://leetcode.cn/problems/jump-game/

题目也是很好理解啊,就是根据数组里每一位的数值来判断是否可以走到结尾,并且每一位数值不是都要走完,可以只走一步,数值是可移动的最大步数。

二、示例讲解

实例1:[2,3,1,1,4]
我们最开始是在 nums[0] 的位置,那么我们接下来可以移动的步数最大是 2 我们可以选择走最大值直接走到nums[2]的位置,这个时候我们可以移动的步数最大值是 1 ,那么我们移动一步走到nums[3],这个时候我们可以移动的步数最大值是 1 ,接下来只需要移动一步我们就走到了数组的最后一位,结束


示例 2: [3,2,1,0,4]
我们最开始是在 nums[0] 的位置,那么接下来我们可以走最大步数是 3 ,我们可以选择走3步,这个时候我们走到nums[3],这个时候我们走不动了,当前运行我们移动的步数为0,说明这里是一个坑不给走了,那么我们重新来一次。

我们最开始是在 nums[0] 的位置,那么接下来我们可以走最大步数是 3 ,我们可以选择走2步,这个时候我们走到nums[2] ,这个时候我们可以移动的最大步数是 1 ,那么我们就移动一步来到nums[3],这个时候我们又进入坑了,还是不行

我们最开始是在 nums[0] 的位置,那么接下来我们可以走最大步数是 3 ,我们可以选择走1步,这个时候我们走到nums[1] ,这个时候我们可以移动的最大步数是 2 ,那么我们就移动 1 步来到nums[2],这个时候我们移动的步数最大值是1,还是会进入坑,那我们在nums[1]的时候移动 2 步,结果还是来到nums[3]还是走不通,所有方法都试过了,失败

三 、算法思路

比较难想,这是一个贪心的题目,贪心的题目有时候特别难想到,主包是研究了好久才理解的。

首先我们看题,我们的最终目的是需要到达数组的最后一个位置,那就意味着到达或者超过都算是到达。我们看数据范围,数组内的数值最小是0,那就是不存在往回移动的情况,那说明我们只有两种选择要么是往前移动,要么原地不动,原地不动结果就是失败,只要能够一直往前移动那么就绝对可以到达

也就是说只要我们不进入值为0的位置那么就没问题,我们根据这个思路我们想一想,开始遍历的时候,我拿到一个值,这个时候我们记录这个值为max(这个值表示当前能够移动到的最远位置),那么接下来我们往后移动又会得到一个值,我们将这个值加上当前的位置和之前记录的值相比较那个大我们就保存下来,只要在移动过程中能够一直保证max一直是大于或者等于当前的移动位置 i,那么说明没有问题

但是如果我们发现位置 i 移动到的位置大于max,那么说明在中间的时候就卡住了不能往后走了,那么就说明失败,当前的数组无法走到最后

max表示我们理论上可以移动到的最远位置i 表示我们实际移动的位置(数组遍历的下标)如果实际移动的位置 大于 max理论上可以移动到的最远位置 ,那说明是不正确的,只有max能够到达的位置才是我们真正能到达的最远位置,如果说max都到不了的地方那么我们也是到不了的


我们看示例二,这一组数据的max是3,最远可以走到nums[3],那么我最远可以走到的地方是3,但是结尾是4,能够走到吗?


我们再看看示例一,在nums[1]的位置的时候max是4(3 + 1),最远可以到达nums[4],那么说明可以到达nums[4]也就是最后的位置。

大家好好理一理,理解max的意义,能够到达的最远位置,代码实现很简单没精神有点不太好理解

四、代码实现:

class Solution { public boolean canJump(int[] nums) { int max = 0;//记录可以到达的最远位置 for(int i = 0 ; i < nums.length ; i++) { if(i <= max) {//当前位置可以到达 max = Math.max(max, nums[i] + i); } else { //出现不可到达的 return false; } } return true; } }

各位佬,如果有什么更加高效的算法欢迎评论区讨论,指导一下主包进步,原诸君共勉

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 13:57:08

企业级校园疫情防控信息管理系统管理系统源码|SpringBoot+Vue+MyBatis架构+MySQL数据库【完整版】

摘要 近年来&#xff0c;全球范围内突发公共卫生事件频发&#xff0c;校园作为人员密集场所&#xff0c;疫情防控压力巨大。传统的人工登记和纸质化管理方式效率低下&#xff0c;难以满足实时监测、快速响应和精准管理的需求。随着信息化技术的快速发展&#xff0c;构建一套高效…

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

一文说清x64和ARM64平台下WinDbg蓝屏日志解析区别

搞懂架构差异&#xff0c;才能真正看懂蓝屏日志&#xff1a;x64与ARM64下WinDbg调试实战精要 你有没有遇到过这样的情况&#xff1f; 在x64电脑上用WinDbg分析蓝屏日志顺风顺水&#xff0c;调用栈清晰、函数名完整&#xff0c; !analyze -v 一句话就定位到出问题的驱动。可换…

作者头像 李华
网站建设 2026/4/21 7:11:59

YOLOv8能否用于月球表面分析?环形山识别尝试

YOLOv8能否用于月球表面分析&#xff1f;环形山识别尝试 在深空探测日益深入的今天&#xff0c;月球不再是遥远幻想中的天体&#xff0c;而是人类即将常态化驻留的前沿阵地。随着LRO&#xff08;月球勘测轨道飞行器&#xff09;持续传回高达0.5米/像素的高清影像&#xff0c;科…

作者头像 李华
网站建设 2026/4/20 9:26:08

校园疫情防控系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】

摘要 随着全球疫情的持续蔓延&#xff0c;校园作为人员密集场所&#xff0c;疫情防控形势尤为严峻。传统的人工登记和纸质管理方式效率低下&#xff0c;难以满足实时监控和快速响应的需求。信息化管理系统的建设成为提升校园疫情防控能力的关键。该系统通过数字化手段整合学生健…

作者头像 李华
网站建设 2026/4/20 8:30:34

上位机软件实现多设备串口通信操作指南

如何让上位机轻松驾驭10台设备的串口通信&#xff1f;实战架构全解析 你有没有遇到过这样的场景&#xff1a;一条产线连着温度传感器、PLC控制器、条码扫描仪和电机驱动器&#xff0c;全都通过串口往上发数据。结果你的上位机软件一运行&#xff0c;界面卡顿、数据错乱、偶尔还…

作者头像 李华
网站建设 2026/4/21 3:10:30

YOLOv8能否识别古代兵器?博物馆藏品分类

YOLOv8能否识别古代兵器&#xff1f;博物馆藏品分类 在数字化浪潮席卷各行各业的今天&#xff0c;博物馆这一承载人类文明记忆的殿堂&#xff0c;也正悄然经历一场技术革命。面对成千上万件尚未系统化标注的文物图像&#xff0c;传统依赖专家人工判读的方式显得力不从心——耗时…

作者头像 李华