跳跃游戏 II (贪心, 动态规划)

题目描述(力扣45题) :

  • 给定一个长度为 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]

解题思路:

  • 以[2, 3, 1, 1, 4] 为例

  • 首先从 0 索引位置出发, 可以跳到 1, 2 索引

  • 1 索引的 3 刚好可以到达最后一个位置的4, 二 2 索引的1 只能到达 3 索引的 1, 所以选择从 1 索引的 3 跳跃, 一共跳两次, 返回 2

  • 简单来说, 就是在本次的跳跃范围以内, 找出下次跳跃距离最远的那一个索引(位置).

解题步骤:

  • int length = nums.length; 获取数组的长度,用于控制循环范围。

  • int end = 0; 这个变量记录了当前跳跃的范围的最远位置。

  • int maxPosition = 0; 这个变量记录了当前跳跃范围内能够到达的最远位置。

  • int steps = 0; 这个变量记录了跳跃的步数。

  • for (int i = 0; i < length - 1; i++) {这是一个循环,从数组的第一个位置开始,遍历到倒数第二个位置。因为在循环中会访问 nums[i+1],所以循环的终止条件是 i < length - 1

  • maxPosition = Math.max(maxPosition, i + nums[i]);更新当前跳跃范围内能够到达的最远位置。i + nums[i] 表示从当前位置能够跳跃到的最远位置,通过 Math.max 来更新 maxPosition

  • if (i == end) {如果当前位置 i 达到了之前记录的跳跃范围的最远位置 end,说明需要进行下一次跳跃了。

以下是代码实现:

复制代码
```java
class Solution {
    public int jump(int[] nums) {
        int end = 0;
        int maxLocal = 0;
        int step = 0;
        for(int i = 0; i <= end && end < nums.length - 1; i++) {
            maxLocal = Math.max(maxLocal, i + nums[i]);
            if(i == end) {
                end = maxLocal;
                step++;
            }
        }

        return step;
    }
}
```
  • 以上是本篇文章的全部内容, 感谢观看
相关推荐
yaoh.wang5 小时前
力扣(LeetCode) 13: 罗马数字转整数 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
T1ssy5 小时前
布隆过滤器:用概率换空间的奇妙数据结构
算法·哈希算法
hetao17338376 小时前
2025-12-12~14 hetao1733837的刷题笔记
数据结构·c++·笔记·算法
鲨莎分不晴6 小时前
强化学习第五课 —— A2C & A3C:并行化是如何杀死经验回放
网络·算法·机器学习
搞科研的小刘选手7 小时前
【ISSN/ISBN双刊号】第三届电力电子与人工智能国际学术会议(PEAI 2026)
图像处理·人工智能·算法·电力电子·学术会议
拉姆哥的小屋7 小时前
从混沌到秩序:条件扩散模型在图像转换中的哲学与技术革命
人工智能·算法·机器学习
Sammyyyyy7 小时前
DeepSeek v3.2 正式发布,对标 GPT-5
开发语言·人工智能·gpt·算法·servbay
sin_hielo8 小时前
leetcode 2110
数据结构·算法·leetcode
Jay20021118 小时前
【机器学习】33 强化学习 - 连续状态空间(DQN算法)
人工智能·算法·机器学习
panzer_maus8 小时前
归并排序的简单介绍
java·数据结构·算法