题目
Given an array of non-negative integers, you are initially positioned at the first index of the array.
Each element in the array represents your maximum jump length at that position.
Determine if you are able to reach the last index.
Example 1:
1 | Input: [2,3,1,1,4] |
Example 2:
1 | Input: [3,2,1,0,4] |
思路
Greedy.
max_num记录当前能到达的最大的位置,可能是之前能跳到的最大的位置,也可能是当前最大的能跳到的位置,即max_num = max(max_num, i+nums[i])
.
如果当前能到达的最大的位置小于当前位置的索引,则表示到达不了,返回False. 如果能跳到最后,返回True.
代码
1 | class Solution(object): |