问题
给你一个非负整数数组 nums
,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标,如果可以,返回 true
;否则,返回 false
。
解答
class Solution {
public boolean canJump(int[] nums) {
int indexMost = 0;
for (int i = 0; i < nums.length; i++) {
if (i<=indexMost){
indexMost = Math.max(i+nums[i],indexMost);
if (indexMost >= nums.length-1){
return true;
}
}
}
return false;
}
}
总结
利用贪心算法,依次循环所能到达的步数,遍历之后得到最大步数