Leetcode45:跳跃游戏 II

题目描述:

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

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

  • 0 <= j <= nums[i]
  • i + j < n

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

代码思路:

  1. 初始化变量
    • num_c:记录跳跃次数,初始化为0。
    • position:记录当前需要到达的目标位置,初始化为数组的最后一个索引(len(nums) - 1),因为目标是到达数组的最后一个位置。
  2. 循环直到到达起始位置
    • 使用一个while循环,条件是position > 0,意味着只要还没到达数组的第一个位置(索引0),就继续循环。
  3. 寻找能够到达当前目标位置的最远起始点
    • 在每次循环中,使用一个for循环遍历从0到position(包括position)的所有位置。
    • 对于每个位置i,检查从i出发能否跳跃到或超过当前的目标位置position(即i + nums[i] >= position)。
    • 如果可以,增加跳跃次数num_c,并将position更新为当前的起始点i,然后跳出内层循环。
  4. 返回结果
    • 循环结束后,返回跳跃次数num_c

代码实现:

复制代码
class Solution:
    def jump(self, nums: List[int]) -> int:
        num_c = 0
        position = len(nums) - 1
        while position > 0:
            for i in range(position + 1):
                if i + nums[i] >= position:
                    num_c += 1
                    position = i
                    break
        return num_c
相关推荐
晨非辰38 分钟前
【数据结构入坑指南】--《层序分明:堆的实现、排序与TOP-K问题一站式攻克(源码实战)》
c语言·开发语言·数据结构·算法·面试
hansang_IR1 小时前
【题解】P2217 [HAOI2007] 分割矩阵 [记忆化搜索]
c++·数学·算法·记忆化搜索·深搜
Voyager_42 小时前
算法学习记录03——二叉树学习笔记:从两道题看透后序位置的关键作用
笔记·学习·算法
我搞slam8 小时前
快乐数--leetcode
算法·leetcode·哈希算法
WWZZ20258 小时前
快速上手大模型:机器学习3(多元线性回归及梯度、向量化、正规方程)
人工智能·算法·机器学习·机器人·slam·具身感知
东方佑9 小时前
从字符串中提取重复子串的Python算法解析
windows·python·算法
西阳未落10 小时前
LeetCode——二分(进阶)
算法·leetcode·职场和发展
通信小呆呆10 小时前
以矩阵视角统一理解:外积、Kronecker 积与 Khatri–Rao 积(含MATLAB可视化)
线性代数·算法·matlab·矩阵·信号处理
CoderCodingNo11 小时前
【GESP】C++四级真题 luogu-B4068 [GESP202412 四级] Recamán
开发语言·c++·算法
一个不知名程序员www11 小时前
算法学习入门---双指针(C++)
c++·算法