【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
相关推荐
ShineWinsu2 小时前
对于C++:继承的解析—上
开发语言·数据结构·c++·算法·面试·笔试·继承
pp起床2 小时前
动态规划 | part05
算法·动态规划
GuangHeAI_ATing2 小时前
国密算法SSD怎么选?这3款国产固态硬盘安全又高速
算法
雨泪丶3 小时前
代码随想录算法训练营-Day34
算法
哈里谢顿3 小时前
Django 应用 OOM(Out of Memory)故障的定位思路和排查方法
python·django
Yzzz-F3 小时前
牛客寒假算法训练营2
算法
甄心爱学习3 小时前
【python】获取所有长度为 k 的二进制字符串
python·算法
iAkuya3 小时前
(leetcode)力扣100 76数据流的中位数(堆)
算法·leetcode·职场和发展
风痕天际4 小时前
Godot扫雷游戏制作记录3——随机埋雷
游戏·游戏引擎·godot
键盘鼓手苏苏4 小时前
Flutter for OpenHarmony: Flutter 三方库 ntp 精准同步鸿蒙设备系统时间(分布式协同授时利器)
android·分布式·算法·flutter·华为·中间件·harmonyos