【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
相关推荐
仰泳的熊猫8 小时前
1148 Werewolf - Simple Version
数据结构·c++·算法·pat考试
chao1898448 小时前
MATLAB中的多重网格算法与计算流体动力学
开发语言·算法·matlab
木盏8 小时前
三维高斯的分裂
开发语言·python
大工mike8 小时前
代码随想录算法训练营第四十四天 | 99.岛屿数量 深搜 99.岛屿数量 广搜 100. 岛屿的最大面积
算法
a程序小傲8 小时前
京东Java面试被问:ZGC的染色指针如何实现?内存屏障如何处理?
java·后端·python·面试
不穿格子的程序员8 小时前
从零开始学算法——链表篇3:合并两个有序链表 + 两数相加
数据结构·算法·链表·dummy
大连好光景8 小时前
批量匿名数据重识别(debug记录)
开发语言·python
暴风鱼划水8 小时前
算法题(Python)哈希表 | 2.两个数组的交集
python·算法·哈希表
清水白石0088 小时前
《深入 Celery:用 Python 构建高可用任务队列的实战指南》
开发语言·python
fufu03119 小时前
Linux环境下的C语言编程(四十二)
linux·c语言·算法