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

然后更新最远能到达位置

相关推荐
老鼠只爱大米11 小时前
LeetCode经典算法面试题 #148:排序链表(插入、归并、快速等五种实现方案解析)
算法·leetcode·链表·插入排序·归并排序·快速排序·链表排序
木井巳11 小时前
【递归算法】计算布尔二叉树的值
java·算法·leetcode·深度优先
睡一觉就好了。11 小时前
直接选择排序
数据结构·算法·排序算法
哈哈不让取名字11 小时前
分布式日志系统实现
开发语言·c++·算法
芬加达11 小时前
leetcode221 最大正方形
java·数据结构·算法
知无不研11 小时前
实现一个整形栈
c语言·数据结构·c++·算法
夏鹏今天学习了吗12 小时前
【LeetCode热题100(98/100)】子集
算法·leetcode·深度优先
DuHz12 小时前
用于汽车应用的数字码调制(DCM)雷达白皮书精读
论文阅读·算法·自动驾驶·汽车·信息与通信·信号处理
李昊哲小课12 小时前
机器学习核心概念与经典算法全解析
人工智能·算法·机器学习·scikit-learn