【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
相关推荐
2401_873204659 小时前
模板编译期循环展开
开发语言·c++·算法
2301_800895109 小时前
2022蓝桥杯b组初赛---备战蓝桥杯版h
职场和发展·蓝桥杯
木心月转码ing9 小时前
Hot100-Day51-TT70爬楼梯
算法
NAGNIP9 小时前
一文搞懂经典的优化算法都有哪些?
算法
站大爷IP9 小时前
Python 合并 PDF 文件(批量处理方法)
python
2501_945423549 小时前
工具、测试与部署
jvm·数据库·python
Oueii9 小时前
数据分析师的Python工具箱
jvm·数据库·python
CoovallyAIHub9 小时前
2.5GB 塞进浏览器:Mistral 开源实时语音识别,延迟不到半秒
深度学习·算法·计算机视觉
weixin_421922699 小时前
使用Scikit-learn进行机器学习模型评估
jvm·数据库·python
会编程的土豆9 小时前
C++中的 lower_bound 和 upper_bound:一篇讲清楚
java·数据结构·算法