题意描述:
给定一个非负整数数组 nums ,你最初位于数组的 第一个下标 。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标。
利用贪心算法,不一定非要明确一次究竟跳几步,每次取最大的跳跃步数,这个就是可以跳跃的覆盖范围。每次取最大跳跃步数(取最大覆盖范围),整体最优解:最后得到整体最大覆盖范围,看是否能到终点。
完整C++代码如下:
class Solution {
public:
bool canJump(vector<int>& nums) {
int end = 0;
if(nums.size() == 1) return true;
for(int i = 0; i <= end; i++){
end = max(i + nums[i], end);
if(end >= nums.size() - 1){
return true;
}
}
return false;
}
};