【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
相关推荐
凤头百灵鸟几秒前
Python语法进阶篇 --- re库、os库、sys库、time库、logging库、random库
python
Lazionr4 分钟前
基础算法 | 模拟算法练习
c++·算法
27669582927 分钟前
jd 变速滑块逆向角度分析
前端·python·京东滑块·京东逆向·京东变速滑块·cfe滑块·wasm逆向
_日拱一卒11 分钟前
LeetCode:17电话号码的字母组合
java·数据结构·算法·leetcode·职场和发展
醉颜凉13 分钟前
Scala自定义Monad实战:从理论到应用的完整指南
大数据·算法·scala
_Evan_Yao15 分钟前
为 LLM 预留“插座”:设计可插拔的 AI 能力底座
java·人工智能·后端·python
信看17 分钟前
I2C 定位程序:LC29H/LC76G ZED-F9P
python
*neverGiveUp*17 分钟前
Django ORM
后端·python·django
STY_fish_201218 分钟前
KMP-前缀函数
算法
feng_you_ying_li21 分钟前
Linux 之线程封装,线程的同步与互斥,互斥锁的介绍
linux·c++·算法