题目
代码(7.25 首刷看解析)
不一定非要明确一次究竟跳几步,每次取最大的跳跃步数,这个就是可以跳跃的覆盖范围。这个范围内,别管是怎么跳的,反正一定可以跳过来。
那么这个问题就转化为跳跃覆盖范围究竟可不可以覆盖到终点!
每次移动取最大跳跃步数(得到最大的覆盖范围),每移动一个单位,就更新最大覆盖范围。
贪心算法局部最优解:每次取最大跳跃步数(取最大覆盖范围),整体最优解:最后得到整体最大覆盖范围,看是否能到终点。
class Solution {
public:
bool canJump(vector<int>& nums) {
int maxStep = 0;
for(int i = 0; i < nums.size() - 1; i++) {
maxStep = max(maxStep, nums[i] + i);
if(maxStep <= i) // 可能碰到了 0,卡住跳不动了
return false;
}
return maxStep >= nums.size()-1;
}
};
代码(9.19 二刷自解)
class Solution {
public:
bool canJump(vector<int>& nums) {
int maxDis = 0;
for(int i = 0; i < nums.size()-1; i++) {
maxDis = max(maxDis, i+nums[i]);
if(maxDis == i)
return false;
}
return true;
}
};