【leetcode--55.跳跃游戏】

思路:贪心算法,尽可能达到最远的位置(因为如果可以达到某个位置,一定可以达到之前的位置)

复制代码
class Solution:
    def canJump(self, nums: List[int]) -> bool:
        max_i = 0
        for i ,jump in enumerate(nums):
            if max_i>=i and (i + jump) > max_i:
                max_i = i + jump
        return max_i >= i

这里的return max_i >= i,注意可以换成return max_i >= len(nums)-1.

首先初始化当前能到达的最远距离,i为当前位置,jump是当前位置的跳数

if判断如果当前位置到达,并且当前位置+跳数>最远位置

然后更新最远能到达位置

相关推荐
曹自标4 分钟前
workflow 拓扑排序算法
windows·算法·排序算法
wen__xvn6 分钟前
代码随想录算法训练营DAY8第四章 字符串part01
算法
mario_z8 分钟前
基于kmines类聚线段算法
前端·javascript·算法
额呃呃9 分钟前
construct对象构造接口
数据库·算法
你怎么知道我是队长13 分钟前
C语言---共用体
c语言·开发语言·算法
cicada1517 分钟前
什么是线程安全?
开发语言·c++·算法
邴越17 分钟前
深度解析TikTok运营的流量池推荐算法
算法·机器学习·推荐算法
科技快报26 分钟前
惠普亮相CES 2026:发布多元创新产品,解锁未来工作与游戏新体验
游戏
GWQ33333 分钟前
地铁跑酷无限金币无限钥匙版游戏攻略分享
游戏
Allen_LVyingbo33 分钟前
医疗AI多智能体资源调度:用Python构建高性能MCU资源池
开发语言·人工智能·python·算法·知识图谱·健康医疗