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

相关推荐
历程里程碑11 分钟前
滑动窗口秒解LeetCode字母异位词
java·c语言·开发语言·数据结构·c++·算法·leetcode
Tandy12356_21 分钟前
手写TCP/IP协议栈——TCP结构定义与基本接口实现
c语言·网络·c++·网络协议·tcp/ip·计算机网络
ghie909024 分钟前
使用直接节点积分法进行无网格法2D悬臂梁计算
算法
Helibo4429 分钟前
2025年12月gesp3级题解
数据结构·c++·算法
p&f°31 分钟前
垃圾回收两种算法
java·jvm·算法
靠沿37 分钟前
Java数据结构初阶——堆与PriorityQueue
java·开发语言·数据结构
点云SLAM40 分钟前
点云配准算法之- GICP算法点云配准概率模型推导和最大似然求解(MLE)
算法·机器人·slam·点云配准·最大似然估计·点云数据处理·gicp算法
禾叙_41 分钟前
HashMap
java·数据结构·哈希算法
曹轲恒42 分钟前
双栈实现队列/双队列实现栈
算法
西幻凌云1 小时前
初始——正则表达式
c++·正则表达式·1024程序员节