【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
相关推荐
那起舞的日子1 分钟前
卡拉兹函数
java·算法
颜酱3 分钟前
滑动窗口算法通关指南:从模板到实战,搞定LeetCode高频题
javascript·后端·算法
Stringzhua4 分钟前
队列-双端队列【Queue2】
java·数据结构·算法·队列
侧岭灵风10 分钟前
yolov5颈部网络图解
深度学习·算法·yolo
Learner__Q11 分钟前
GPT模型入门教程:从原理到实现
python·gpt
夕除15 分钟前
js--21
java·python·算法
冬夜戏雪16 分钟前
单词拆分/分割等和子集
算法·leetcode·职场和发展
追随者永远是胜利者17 分钟前
(LeetCode-Hot100)21. 合并两个有序链表
java·算法·leetcode·链表·go
重生之后端学习20 分钟前
994. 腐烂的橘子
java·开发语言·数据结构·后端·算法·深度优先
癫狂的兔子25 分钟前
【Python】【机器学习】逻辑回归
python·机器学习·逻辑回归