【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
相关推荐
NAGNIP3 小时前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP3 小时前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮3 小时前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法
用户8356290780518 小时前
无需 Office:Python 批量转换 PPT 为图片
后端·python
爱理财的程序媛9 小时前
openclaw 盯盘实践
算法
markfeng810 小时前
Python+Django+H5+MySQL项目搭建
python·django
GinoWi10 小时前
Chapter 2 - Python中的变量和简单的数据类型
python
JordanHaidee10 小时前
Python 中 `if x:` 到底在判断什么?
后端·python
ServBay10 小时前
10分钟彻底终结冗长代码,Python f-string 让你重获编程自由
后端·python