【LeetCode】每日一题:跳跃游戏 II

给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。

每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处:

0 <= j <= nums[i]

i + j < n

返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]。

解题思路

DP

AC代码

python 复制代码
class Solution:
    def jump(self, nums: List[int]) -> int:
        if len(nums) < 2:
            return 0
        if len(nums) == 2:
            return 1

        n = len(nums) - 1
        f = [1001 for _ in nums]

        for i in range(n - 1, -1, -1):
            if nums[i] + i >= n:
                f[i] = 1
            else:
                f[i] = 1 + min(f[i+1:i+nums[i]+1]) if nums[i] != 0 else 1001
        return f[0]
相关推荐
QxQ么么20 小时前
移远通信(桂林)26校招-助理AI算法工程师-面试纪录
人工智能·python·算法·面试
执笔论英雄21 小时前
Slime异步原理(单例设计模式)4
开发语言·python·设计模式
小徐敲java1 天前
python使用s7协议与plc进行数据通讯(HslCommunication模拟)
开发语言·python
猫头虎1 天前
如何解决 pip install 编译报错 fatal error: hdf5.h: No such file or directory(h5py)问题
人工智能·python·pycharm·开源·beautifulsoup·ai编程·pip
Mz12211 天前
day05 移动零、盛水最多的容器、三数之和
数据结构·算法·leetcode
SoleMotive.1 天前
如果用户反映页面跳转得非常慢,该如何排查
jvm·数据库·redis·算法·缓存
p***23361 天前
python的sql解析库-sqlparse
数据库·python·sql
念越1 天前
判断两棵二叉树是否相同(力扣)
算法·leetcode·入门
陈奕昆1 天前
n8n实战营Day1课时3:高频节点解析+Webhook表单同步Excel实操
人工智能·python·n8n
未可知7771 天前
软件设计师(上午题4)、面向对象、uml、设计模式
设计模式·职场和发展·uml