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

相关推荐
进击的小头2 分钟前
一阶IIR低通滤波器:从原理到嵌入式实战
c语言·算法
五_谷_丰_登2 分钟前
C++模板元编程学习——模板简介
c++·stl·c++标准库
2301_8112329815 分钟前
C++中的契约编程
开发语言·c++·算法
2401_8290040215 分钟前
C++中的访问者模式
开发语言·c++·算法
D_evil__22 分钟前
【Effective Modern C++】第三章 转向现代C++:13. 优先选用const_iterator,而非iterator
c++
青槿吖23 分钟前
第二篇:JDBC进阶骚操作:防注入、事务回滚、连接池优化,一篇封神
java·开发语言·jvm·算法·自动化
sin_hielo23 分钟前
leetcode 1984
数据结构·算法·leetcode
赵萱婷23 分钟前
C++17 nodiscard属性深度解析
开发语言·c++·经验分享
kklovecode24 分钟前
C++对C语言的增强
c语言·开发语言·c++