【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
相关推荐
BieberChen15 小时前
匈牙利匹配算法 (Hungarian Algorithm) 详解
算法
春栀怡铃声15 小时前
常考排序的梳理
数据结构·算法·排序算法
第二只羽毛15 小时前
第六章 图
大数据·数据结构·算法·深度优先·图论·广度优先·宽度优先
好家伙VCC15 小时前
**CQRS模式实战:用Go语言构建高并发读写分离架构**在现代分布式系统中,随着业务复杂度的提升和用户量的增长,传统的单数据库模型逐
java·数据库·python·架构·golang
fy1216315 小时前
Java进阶——IO 流
java·开发语言·python
flyfox15 小时前
OpenClaw(龙虾) Skills 实战开发指南
人工智能·python·源码
魔士于安15 小时前
unity 动物包 大象 鹿 狐狸
游戏·unity·游戏引擎·贴图·模型
深藏功yu名15 小时前
Day27:LangGraph 实战落地|Tool_RAG + 并行子图 + 持久化部署,打造工业级 AI Agent
人工智能·python·ai·pycharm·rag·langgrap
csuzhucong15 小时前
puzzle(1052)仙人指路
算法