【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判断如果当前位置到达,并且当前位置+跳数>最远位置

然后更新最远能到达位置

相关推荐
sul.i6 分钟前
浅析·指针
算法
春日见8 分钟前
策略梯度算法
算法
Brilliantwxx9 分钟前
【算法从零到千】【1-7】 双指针算法
开发语言·c++·笔记·算法·leetcode·推荐算法
小许同学记录成长11 分钟前
孔洞修补算法
算法
随意起个昵称12 分钟前
线性dp-计数类题目9(斐波那契字符串)
算法·动态规划
菜菜的顾清寒18 分钟前
力扣HOT100(49)动态规划 -- 打家劫舍
算法·leetcode·动态规划
葡萄城技术团队21 分钟前
观察生活:人是如何分词的
算法·生活
装不满的克莱因瓶27 分钟前
什么是特征分解?从数学定义到现实问题的映射
人工智能·数学·算法·机器学习·ai·特征分解
killerbasd31 分钟前
总结 6.1
算法
「維他檸檬茶」35 分钟前
大模型算法学习2026.6.1
学习·算法·大模型·nlp