题目描述
给定一个非负整数数组,你最初位于数组的第一个位置。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个位置。
输入: [2,3,1,1,4]
输出: true
解题思路
别想那么多,就挨着跳吧。(贪心策略,想明白之后就很简单了)
- 如果某一个作为 起跳点 的格子可以跳跃的距离是 3,那么表示后面 3 个格子都可以作为 起跳点。
- 可以对每一个能作为 起跳点 的格子都尝试跳一次,把 能跳到最远的距离 不断更新。
- 如果可以一直跳到最后,就成功了。
参考代码
class Solution {
public:
bool canJump(vector<int>& nums) {
if(nums.size() == 0)
return false;
int farthestIndex = 0;
for(int i = 0; i < nums.size(); i++){
if(i > farthestIndex)
return false;
farthestIndex = max(farthestIndex, i + nums[i]);
}
return true;
}
};
探讨了如何使用贪心策略解决跳跃游戏问题,通过遍历数组并更新可达最远距离来判断是否能到达最后一个位置。
376

被折叠的 条评论
为什么被折叠?



