leetcode 55. 跳跃游戏

2023.7.29

本题不用纠结于可以跳几步,可以聚焦于**覆盖范围,**即 当前位置+当前跳数 能够覆盖的范围,若这个范围足以到达最后一个位置,则返回true;若for循环结束,则还没返回true,则返回false。 下面看代码:

cpp 复制代码
class Solution {
public:
    bool canJump(vector<int>& nums) {
        int cover = 0;
        for(int i=0; i <= cover; i++)
        {
            if(i+nums[i] > cover) cover = i+nums[i];
            if(cover >= nums.size()-1) return true;
        }
        return false;
    }
};

ps:因为cover是覆盖范围,所以for循环的终止条件是i<=cover,最后一个位置是可以取到的。

相关推荐
地平线开发者22 分钟前
征程 6X Camera 接入数据评估
算法·自动驾驶
Storynone24 分钟前
【Day23】LeetCode:455. 分发饼干,376. 摆动序列,53. 最大子序和
python·算法·leetcode
小付同学呀42 分钟前
C语言学习(八)——C判断(switch语句)
c语言·学习·算法
zhooyu1 小时前
二维坐标转三维坐标的实现原理
c++·3d·opengl
zhojiew1 小时前
为agent实现渐进式Skills能力的思考和实践
linux·python·算法
10Eugene1 小时前
C++/Qt自制八股文
java·开发语言·c++
「QT(C++)开发工程师」1 小时前
C++11 新特性 正则表达式、随机数库、元组
c++·正则表达式
ATAOL1 小时前
数据结构一
数据结构·算法
zyq99101_12 小时前
Python日期处理实战代码
python·算法·蓝桥杯
free-elcmacom2 小时前
C++ 默认参数详解:用法、规则与避坑指南
开发语言·c++