给定一个非负整数数组 nums ,你最初位于数组的 第一个下标 。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标。
时间: 2024-01-22 11:38:25 浏览: 78
B:找出数组中最大数和其下标
这是一道典型的贪心算法题目,我们可以从前往后遍历数组,记录当前能够到达的最远位置,如果当前位置超过了这个最远位置,说明无法到达最后一个下标,则返回false。如果遍历结束后,最远位置大于等于最后一个下标,则返回true。
以下是示例代码:
```
bool canJump(vector<int>& nums) {
int n = nums.size();
int maxPos = 0;
for (int i = 0; i < n; i++) {
if (i > maxPos) {
return false;
}
maxPos = max(maxPos, i + nums[i]);
if (maxPos >= n - 1) {
return true;
}
}
return false;
}
```
时间复杂度:O(n),其中 n 是数组的长度。
阅读全文