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,最后一个位置是可以取到的。

相关推荐
NiNi_suanfa17 小时前
【Qt】Qt 批量修改同类对象
开发语言·c++·qt
信奥胡老师17 小时前
苹果电脑(mac系统)安装vscode与配置c++环境,并可以使用万能头文件全流程
c++·ide·vscode·macos·编辑器
妖灵翎幺17 小时前
C++ 中的 :: 操作符详解(一切情况)
开发语言·c++·ide
风筝在晴天搁浅18 小时前
代码随想录 718.最长重复子数组
算法
kyle~18 小时前
算法---回溯算法
算法
star _chen18 小时前
C++实现完美洗牌算法
开发语言·c++·算法
hzxxxxxxx18 小时前
1234567
算法
繁星星繁19 小时前
【C++】脚手架学习笔记 gflags与 gtest
c++·笔记·学习
Sylvia-girl19 小时前
数据结构之复杂度
数据结构·算法
CQ_YM19 小时前
数据结构之队列
c语言·数据结构·算法·