【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
相关推荐
斯文by累7 分钟前
Python环境搭建
开发语言·python
.似水33 分钟前
Python requests
开发语言·python
不会飞的鲨鱼35 分钟前
FastMoss 国际电商Tiktok数据分析 JS 逆向 | MD5加密
javascript·python·数据挖掘·数据分析
tanyyinyu1 小时前
Python列表:高效灵活的数据存储与操作指南
开发语言·windows·python
加油搞钱加油搞钱1 小时前
鹰盾加密器“一机一码”技术全维度剖析:从底层实现到生态防护体系
开发语言·网络·python
朝朝又沐沐1 小时前
基于算法竞赛的c++编程(28)结构体的进阶应用
开发语言·c++·算法
站大爷IP1 小时前
Python项目文件组织与PyCharm实践:打造高效开发环境
python
nbbsn2 小时前
第四十天打卡
python·深度学习·机器学习
ZHOU_WUYI2 小时前
Flask RESTful 示例
python·flask·restful
代码雕刻家2 小时前
7.4.分块查找
c语言·数据结构·算法