【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
相关推荐
小白程序员成长日记11 小时前
2025.11.16 力扣每日一题
算法
Kuo-Teng11 小时前
LeetCode 118: Pascal‘s Triangle
java·算法·leetcode·职场和发展·动态规划
Greedy Alg11 小时前
LeetCode 32. 最长有效括号(困难)
算法
Q_Q51100828511 小时前
python+django/flask的宠物用品系统vue
spring boot·python·django·flask·node.js·php
hmbbcsm12 小时前
练习python题目小记(五)
开发语言·python
蓝桉~MLGT12 小时前
Python学习历程——文件
python·学习·策略模式
循环过三天12 小时前
7.5、Python-匿名函数lambda
笔记·python·学习
ShineWinsu12 小时前
对于数据结构:链式二叉树的超详细保姆级解析—中
数据结构·c++·算法·面试·二叉树·校招·递归
仟濹12 小时前
【Java 基础】3 面向对象 - this
java·开发语言·python