当前位置:网站首页>leetcode-45-跳跃游戏 II
leetcode-45-跳跃游戏 II
2022-08-09 00:27:00 【前端码农小王】
给你一个非负整数数组 nums
,你最初位于数组的第一个位置。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
你的目标是使用最少的跳跃次数到达数组的最后一个位置。
假设你总是可以到达数组的最后一个位置。
示例 1:
输入: nums = [2,3,1,1,4]
输出: 2
解释: 跳到最后一个位置的最小跳跃数是 2。
从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。
示例 2:
输入: nums = [2,3,0,1,4]
输出: 2
提示:
1 <= nums.length <= 104
0 <= nums[i] <= 1000
解题思路
本题要我们求出调到输入数组最后一个位置所需的步数,想要求得调到最后一个位置所需的步数,就要在每次跳跃的时候跳的尽可能的远,那如何才能在每一步都跳的最远呢?根据题意可以每一个位置可以跳跃该位置整数的距离,所以我们应该在该范围内找一个下一次可以跳的最远的位置,也就是 i+nums[i]
最大。所以本题可以初始化一个 tail
指针指向当前所在位置,step
记录跳跃次数。当 tail+nums[tail]
小于 nums.length-1
时,不停向后跳跃,并且每一次找到下一次可以跳的最远的位置进行跳跃,并更新 tail
和 step
,最后当 tail+nums[tail] >= nums.length-1
,就说明已经到达了数组最后的位置,返回 step
即可。
代码实现
var jump = function(nums) {if(nums.length===1){return 0}let tail = 0let step = 1// 如果当前下标加上当前值达不到数组末尾位置,继续执行while(tail+nums[tail]<nums.length-1){let targetIndexlet max = 0// 每次在范围内找到可以跳的最远的位置跳for(let i = tail;i<=tail+nums[tail];i++){if(i+nums[i]>max){max = i+nums[i]targetIndex = i}}tail = targetIndexstep++}return step
}
至此我们就完成了 leetcode-45-跳跃游戏 II
如有任何问题或建议,欢迎留言讨论!
边栏推荐
猜你喜欢
Early departure, learning source half a year, finally got the ants Offer to share the interview process
云服务器可以用来做什么?有什么用途?
插值拟合——数据处理或预测
基本控件属性
JS data types
笔记&代码 | 统计学——基于R(第四版) 第四章随机变量的概率分布
wordpress入门基本操作,网站安全防护及常用插件(建站必看教程)
【C语言刷题】链表中快慢指针的应用
【 StoneDB Class 】 introductory lesson 3: StoneDB installation of compilation
手把手教你云服务器如何搭建typecho博客网站(包括配置免费SSL证书)
随机推荐
Unity3D小白学习日记(01):如何把物体移动到鼠标点击处
什么是阿里云服务器系统盘和数据盘?
逐片元-兰伯特光照模型
笔记&代码 | 统计学——基于R(第四版) 第四章随机变量的概率分布
XShell用命令行打包jar包(详细步骤)
关于cordova的InAppBrowser插件的几点问题
2020-10-17
Refract-折射
动态style定义背景渐变
Unity学习笔记--摄像机插值跟随
利用Ehcache分布式缓存,轻松打造商业级高并发、高性能API接口!
ShadowMap-Example
vscode 中新建文件自动显示作者,日期等配置
对纹理进行uv坐标偏移
GaN图腾柱无桥 Boost PFC(单相)四(仿真理解)
node工具之nodemon
矩阵乘法总结
图像分割、图像超分辨率简介
架构组学习总结
GaN图腾柱无桥 Boost PFC(单相)五-细节处理