【LeetCode】每日一题:跳跃游戏

给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。

判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。

解题思路

每个位置算自己最远能跳到哪里,那么倒过来考虑,更新需要跳到的位置即可

AC代码

python 复制代码
class Solution:
    def canJump(self, nums: List[int]) -> bool:
        if len(nums) < 2:
            return True
        nums = [i + v for i, v in enumerate(nums)]

        target = len(nums) - 1
        for i in range(len(nums) - 2, -1, -1):
            if nums[i]  >= target:
                target = i
        
        return target == 0
相关推荐
jason_renyu几秒前
图书馆管理系统完整开发文档(Flask + Vue3 + Element Plus + MySQL )
python·python学习·flask毕业设计例子·flask学习例子·flask入门
费弗里几秒前
新版本Dash完美支持原生FastAPI后端
python·fastapi·dash
Ulyanov2 分钟前
《玩转QT Designer Studio:从设计到实战》 QT Designer Studio环境搭建与核心工作区详解
开发语言·python·qt·系统仿真·雷达电子战系统仿真
不知名的老吴3 分钟前
案例教学:最长递增子序列问题
数据结构·算法·动态规划
样例过了就是过了3 分钟前
LeetCode热题100 杨辉三角
c++·算法·leetcode·动态规划
2301_816660214 分钟前
c++ openimageio工具 c++如何使用oiiotool进行图像批量处理
jvm·数据库·python
m0_377618239 分钟前
SQL性能调优:为何尽量使用窗口函数而非关联子查询
jvm·数据库·python
念越11 分钟前
算法每日一题 Day05|双指针解决盛最多水的容器问题
算法·力扣
2301_7965885011 分钟前
如何监控MongoDB索引碎片的产生_compact命令与碎片整理
jvm·数据库·python
eggrall13 分钟前
Leetcode 最大连续 1 的个数 III(medium)
算法·leetcode·职场和发展