【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
相关推荐
weixin_4624462315 小时前
Python用Flask后端解析Excel图表,Vue3+ECharts前端动态还原(附全套代码)
前端·python·flask·echats
wen__xvn15 小时前
基础算法集训第03天:递推
算法
偷星星的贼1115 小时前
如何为开源Python项目做贡献?
jvm·数据库·python
秋刀鱼程序编程15 小时前
Java基础入门(七)---异常处理
java·开发语言·python
wen__xvn15 小时前
算法基础集训第19天:广度优先搜索
算法·宽度优先
二十雨辰15 小时前
[python]-基础语法
python
小白学大数据15 小时前
基于 Python 的知网文献批量采集与可视化分析
开发语言·爬虫·python·小程序
Ulyanov15 小时前
PyVista战场可视化实战(一):构建3D战场环境的基础
开发语言·python·3d·tkinter·gui开发
这就是佬们吗15 小时前
力扣---leetcode48
java·笔记·后端·算法·leetcode·idea
fai厅的秃头姐!15 小时前
01-python基础-day01python基础
python