【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
相关推荐
苦藤新鸡2 分钟前
19.旋转输出矩阵
c++·算法·leetcode·力扣
zsffuture3 分钟前
RKNN 8位量化全解析:算法差异与粒度选择实战指南
算法
玄冥剑尊3 分钟前
贪心算法深化 II
算法·贪心算法
Pluchon3 分钟前
硅基计划4.0 算法 动态规划入门
java·数据结构·算法·动态规划
玄冥剑尊4 分钟前
贪心算法深化 III
算法·贪心算法
Java程序员威哥11 分钟前
Java应用容器化最佳实践:Docker镜像构建+K8s滚动更新(生产级完整模板+避坑指南)
java·开发语言·后端·python·docker·kubernetes·c#
资深设备全生命周期管理11 分钟前
【实时显示画面在视频上,捕获轮廓】
python
qq_21539789715 分钟前
python环境无网络环境导入依赖
开发语言·python
三七吃山漆27 分钟前
[护网杯 2018]easy_tornado
python·web安全·ctf·tornado
wen__xvn29 分钟前
算法刷题目录
算法