1、题目:跳跃游戏
给定一个非负整数数组 nums ,你最初位于数组的 第一个下标 。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标。

2、解题思路
每次取最大跳跃步数(取最大覆盖范围),最后得到整体最大覆盖范围,看是否能到终点。

3、代码
class Solution {
public:
bool canJump(vector<int>& nums) {
int cover = 0;
if (nums.size() == 1) return true; // 只有一个元素,就是能达到
for (int i = 0; i <= cover; i++) { // 注意这里是小于等于cover
cover = max(i + nums[i], cover);
if (cover >= nums.size() - 1) return true; // 说明可以覆盖到终点了
}
return false;
}
};
该博客讨论了一种名为跳跃游戏的算法问题,其中玩家从数组的第一个元素开始,每次可以跳跃最大为当前位置的数值。目标是判断是否能到达数组的最后一个元素。解题策略是动态规划,每次选取当前范围内能跳得最远的位置更新覆盖范围,直到覆盖到终点或无法前进。提供的代码展示了C++实现的解决方案。
841

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



