【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
相关推荐
_日拱一卒19 小时前
LeetCode:230二叉搜索树中第K小的元素
算法
m0_5913647319 小时前
CSS 背景图滑动切换:纯 CSS 实现右进左出轮播效果
jvm·数据库·python
2401_8242226919 小时前
Python测试代码如何实现自解释_使用pytest描述性命名规范
jvm·数据库·python
接着奏乐接着舞19 小时前
springboot 常用注解
spring boot·后端·python
woxihuan12345619 小时前
MySQL 中高效存储与查询时间数据的最佳实践
jvm·数据库·python
Struggle_975519 小时前
算法知识-背包dp
算法
2301_8092047019 小时前
如何用 structuredClone 原生函数实现复杂对象深拷贝
jvm·数据库·python
德迅云安全-小潘19 小时前
游戏行业如何保障网络安全
服务器·网络·游戏
2401_8987176619 小时前
Golang Gin如何定义路由和路由组_Golang Gin路由教程【实用】
jvm·数据库·python
甄心爱学习19 小时前
【项目实训(个人6)】
人工智能·python·个人开发