题目
给定一个非负整数数组 nums
,你最初位于数组的 第一个下标 。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标。
解题思路
遍历数组,维护一个当前能到达最远距离的下标 cur
,让其与遍历数组过程中的下标 i
做比较,如果下标 i
大于下标 cur
,则表示当前节点不能到达,即返回 false
。其中, cur = max(cur, i + nums[i])
,表示到当前节点为止,能到达的最远距离的下标。
代码
class Solution {
public boolean canJump(int[] nums) {
int cur = 0, length = nums.length;
for (int i = 0; i < length; i++) {
if (i > cur) return false;
cur = Math.max(cur, i + nums[i]);
}
return true;
}
}