问题
给你一个非负整数数组 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;}
}
总结
利用贪心算法,依次循环所能到达的步数,遍历之后得到最大步数