【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
相关推荐
DYS_房东的猫6 分钟前
《 C++ 零基础入门教程》第6章:模板与 STL 算法 —— 写一次,用万次
开发语言·c++·算法
Tim_107 分钟前
【算法专题训练】37、前缀树&二叉树
算法
副露のmagic17 分钟前
更弱智的算法学习 day34
python·学习
NineData21 分钟前
第三届数据库编程大赛-八强决赛成绩揭晓
数据库·算法·代码规范
AllFiles22 分钟前
用Python turtle画出标准五星红旗,原来国旗绘制有这么多数学奥秘!
python
亲爱的非洲野猪27 分钟前
Java线程池深度解析:从原理到最佳实践
java·网络·python
雍凉明月夜35 分钟前
深度学习之目标检测yolo算法Ⅱ(v4)
深度学习·算法·yolo·目标检测
用户13779404999339 分钟前
基于遗传算法实现自动泊车+pygame可视化
python
4***17541 小时前
强化学习中的蒙特卡洛方法
python
pen-ai1 小时前
打通 Python 与 C++ 的参数传递机制
开发语言·c++·python