LeetCode79 - 跳跃游戏 II
📝 题目描述
题目链接:跳跃游戏 II
给定一个长度为 n 的 0 索引整数数组 nums。初始位置在下标 0。
每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说,如果你在索引 i 处,你可以跳转到任意 (i + j) 处:
0 <= j <= nums[i]且i + j < n
返回到达 n - 1 的最小跳跃次数。测试用例保证可以到达 n - 1。
示例:
1 | 示例 1: |
提示:
1 <= nums.length <= 10^40 <= nums[i] <= 1000题目保证可以到达 n - 1
💡 解题思路
方法一:贪心算法
其实核心思想只有一句话:
在当前可达范围内,找到下一步可达的最大范围。
从覆盖范围出发,不管怎么跳,覆盖范围内一定是可以跳到的,以最小的步数增加覆盖范围,覆盖范围一旦覆盖了终点,得到的就是最少步数。这里需要统计两个覆盖范围,当前这一步的最大覆盖和下一步最大覆盖。
如果移动下标达到了当前这一步的最大覆盖最远距离了,还没有到终点的话,那么就必须再走一步来增加覆盖范围,直到覆盖范围覆盖了终点。
这里有个特殊情况需要考虑,当移动下标达到了当前覆盖的最远距离下标时
- 如果当前覆盖最远距离下标小于集合终点,步数就加一,还需要继续走。
- 如果当前覆盖最远距离下标大于等于集合终点,步数不用加一,因为不能再往后走了。
方法二:暴力解法
我们的目标是到达数组的最后一个位置,因此我们可以考虑最后一步跳跃前所在的位置,该位置通过跳跃能够到达最后一个位置。
如果有多个位置通过跳跃都能够到达最后一个位置,那么我们应该如何进行选择呢?直观上来看,我们可以“贪心”地选择距离最后一个位置最远的那个位置,也就是对应下标最小的那个位置。因此,我们可以从左到右遍历数组,选择第一个满足要求的位置。
找到最后一步跳跃前所在的位置之后,我们继续贪心地寻找倒数第二步跳跃前所在的位置,以此类推,直到找到数组的开始位置。
🔧 代码实现
1、贪心算法
1 | class Solution { |
2、暴力解法
1 | class Solution { |
📊 复杂度分析
1、贪心算法
- 时间复杂度:,其中 是数组长度。
- 空间复杂度:。
2、暴力解法
- 时间复杂度:,其中 是数组长度。有两层嵌套循环,在最坏的情况下,例如数组中的所有元素都是 ,
position需要遍历数组中的每个位置,对于position的每个值都有一次循环。 - 空间复杂度:。
🎯 总结
- 核心思想:骑驴找马思想。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 很多时候不懂事!