给你一个非负整数数组 nums,你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 你的目标是使用最少的跳跃次数到达数组的最后一个位置。 假设你总是可以到达数组的最后一个位置。
时间: 2023-04-15 14:04:48 浏览: 119
python 实现给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的子集(幂集)
5星 · 资源好评率100%
题目描述:
给定一个非负整数数组 nums,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的最大长度。你的目标是使用最少的跳跃次数到达数组的最后一个位置。假设你总是可以到达数组的最后一个位置。
解题思路:
贪心算法。我们可以用一个变量 end 表示当前能够到达的最远位置,用一个变量 maxPos 表示当前能够到达的最远位置的最大值,用一个变量 step 表示跳跃次数。遍历数组,如果当前位置 i 大于 end,说明需要进行一次跳跃,将 end 更新为 maxPos,step 加一。在遍历过程中,不断更新 maxPos 的值,即 maxPos = max(maxPos, i + nums[i])。
代码实现:
阅读全文