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

相关推荐
XLYcmy27 分钟前
高级密码猜测生成器AdvancedPasswordGenerator密码生成器程序详细分析
开发语言·python·算法·网络安全·开发工具·源代码·口令安全
冉佳驹1 小时前
C++ ——— 深入解析多态从语法到底层实现的完整知识体系
c++·多态·抽象类·虚函数·虚函数表
STY_fish_20121 小时前
可持久化线段树
数据结构
im_AMBER1 小时前
Leetcode 93 找出临界点之间的最小和最大距离
c++·笔记·学习·算法·leetcode
有一个好名字2 小时前
力扣:除自身以外数组的乘积
java·算法·leetcode
lzksword2 小时前
C++BuilderXE12查询所有进程名程与句柄
c++
千里马-horse2 小时前
React Native 源码分析 -- jsi.h
javascript·c++·react native·react.js·jsi
bkspiderx2 小时前
C++中的访问控制:private、public与protected的深度解析
开发语言·c++·算法·访问控制·private·public·protected
ullio3 小时前
arc207c - Combine to Make Non-decreasing
算法
ZhuNian的学习乐园3 小时前
LLM对齐核心:RLHF 从基础到实践全解析
人工智能·python·算法