【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
相关推荐
Frostnova丶17 小时前
【算法笔记】数学知识
笔记·算法
生而为虫18 小时前
[学习记录] 幼儿学习拼音html游戏
学习·游戏
吴可可12318 小时前
AutoCAD 2016与2014二次开发关键差异
算法
世辰辰辰18 小时前
批量修改图片/文本名子
开发语言·python·批量修改文件名
雨白19 小时前
哈希:以时间换空间的算法实战
算法
myenjoy_120 小时前
MQTT 与 Sparkplug B——从车间到云端的最后一公里
网络·python
San813_LDD21 小时前
[数据结构]LeetCode学习
数据结构·算法·图论
x1387028595721 小时前
c语言排雷游戏(基础版9*9)
c语言·算法·游戏
颜酱21 小时前
LangChain 输出解析器:把模型回复变成你要的数据
python·langchain