2023.7.29
本题不用纠结于可以跳几步,可以聚焦于覆盖范围,即 当前位置+当前跳数 能够覆盖的范围,若这个范围足以到达最后一个位置,则返回true;若for循环结束,则还没返回true,则返回false。 下面看代码:
class Solution {
public:
bool canJump(vector<int>& nums) {
int cover = 0;
for(int i=0; i <= cover; i++)
{
if(i+nums[i] > cover) cover = i+nums[i];
if(cover >= nums.size()-1) return true;
}
return false;
}
};
ps:因为cover是覆盖范围,所以for循环的终止条件是i<=cover,最后一个位置是可以取到的。
2023.10.9
二刷。 java代码如下:
class Solution {
public boolean canJump(int[] nums) {
int cover = 0; //能覆盖的最大范围
for(int i=0; i<=cover; i++){
cover = Math.max(cover,i+nums[i]);
if(cover >= nums.length-1) return true;
}
return false;
}
}