【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
相关推荐
培培说证6 分钟前
2026财务岗位如何快速提升自身能力
python
redaijufeng6 分钟前
C++雾中风景7:闭包
c++·算法·风景
努力攻坚操作系统8 分钟前
编程语言编译运行机制对比:C / Java / Python
java·c语言·python
godspeed_lucip17 分钟前
LLM和Agent——专题6:Multi Agent 入门(5)
人工智能·python
远程软件小助理34 分钟前
ToDesk节点繁忙、向日葵免费试用受限,还有什么免费好用的远程软件推荐?
经验分享·游戏·远程工作
小欣加油36 分钟前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
德迅--文琪1 小时前
游戏盾筑牢网络游戏防攻击安全防线
安全·游戏
尽兴-1 小时前
2.1 向量基础:Embedding、余弦相似度、欧氏距离、向量检索
算法·embedding·欧氏距离·向量检索·余弦相似度
Metaphor6921 小时前
使用 Python 给 PDF 设置背景色或背景图
数据库·python·pdf