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

相关推荐
Watermelo61714 小时前
如何优雅地导出 VS Code 项目目录结构
前端·javascript·vue.js·vscode·算法·性能优化·node.js
飞Link14 小时前
【算法与模型】One-Class SVM 异常检测全解析:原理、实例、项目实战与工程经验
人工智能·python·算法·机器学习·支持向量机
ZouZou老师16 小时前
C++设计模式之工厂方法模式:以家具生产为例
c++·设计模式·工厂方法模式
MicroTech202516 小时前
MLGO微算法科技发布突破性运动想象脑机接口算法,高精度与低复杂度兼得
科技·算法
cici1587416 小时前
基于不同算法的数字图像修复Matlab实现
算法·计算机视觉·matlab
fish_xk19 小时前
c++中的引用和数组
开发语言·c++
有点。1 天前
C++ ⼀级 2024 年 03 ⽉
c++
CC.GG1 天前
【C++】二叉搜索树
java·c++·redis
Savior`L1 天前
二分算法及常见用法
数据结构·c++·算法
深海潜水员1 天前
OpenGL 学习笔记 第一章:绘制一个窗口
c++·笔记·学习·图形渲染·opengl