优化排名推广技术网站,深圳小程序app定制开发,php二次网站开发步骤,广州网站seo地址题目#xff1a;45. 跳跃游戏 II
难度#xff1a;中等
给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。
每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说#xff0c;如果你在 nums[i] 处#xff0c;你可以跳转到任意 nums[i j] 处:
0 45. 跳跃游戏 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]。 示例 1:
输入: nums [2,3,1,1,4]
输出: 2
解释: 跳到最后一个位置的最小跳跃数是 2。从下标为 0 跳到下标为 1 的位置跳 1 步然后跳 3 步到达数组的最后一个位置。示例 2:
输入: nums [2,3,0,1,4]
输出: 2提示:
1 nums.length 1040 nums[i] 1000题目保证可以到达 nums[n-1]
一、模式识别
1.贪心算法
跳跃游戏是常见的贪心算法题
通过贪心地计算本次的最远跳跃距离得到到终点的最远跳跃距离
方法是逐步遍历动态更新下一个最远条约距离
当达到本次的最远距离时最小步数 1且下一个变成本次的最远距离
二、代码实现
class Solution:def jump(self, nums: List[int]) - int:ans 0cur nex 0n len(nums)for i in range(n - 1):nex max(nex, i nums[i])if i cur:ans 1cur nexreturn ans