11-20 P55 跳跃游戏
题目描述
给你一个非负整数数组 nums
,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标,如果可以,返回 true
;否则,返回 false
。
题解
把跳跃的步数看作覆盖范围,能够以覆盖范围作为起点跳跃,若能覆盖到最后一个元素,返回true
,若在覆盖范围内跳跃仍然不能覆盖到最后一个元素,返回false
代码
var canJump = function(nums){
let n = nums.length
let cover = 0
for(let i = 0;i<=cover;i++){
cover = Math.max(nums[i] + i,cover)
if(cover>=n-1){
return true
}
}
return false
}