1、题目:
给定一个长度为 n
的 0 索引整数数组 nums
。初始位置为 nums[0]
。
每个元素 nums[i]
表示从索引 i
向前跳转的最大长度。换句话说,如果你在 nums[i]
处,你可以跳转到任意 nums[i + j]
处:
返回到达 nums[n - 1]
的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]
。
2、分析特点:
- 这道题是典型的贪心算法,通过局部最优解得到全局最优解。
反向思维解决
: 每次都找最左位置-最后一个位置,距离最远,即最大概率最小跳跃次数。- 【解题口:寻找最左位置–寻找的次数,即最小跳跃次数】
3、代码:
class solution {
public int jump(int[] nums) {
int position = nums.length - 1;
int steps = 0;
while (position > 0) {
for (int i = 0; i < position; i++) {
if (i + nums[i] >= position) {
position = i;
steps++;
break;
}
}
}
return steps;
}
}
4、复杂度分析:
5、总结:
- 这道题是典型的贪心算法,通过局部最优解得到全局最优解。
反向思维解决
: 每次都找最左位置-最后一个位置,距离最远,即最大概率最小跳跃次数。- 【解题口:寻找最左位置–寻找的次数,即最小跳跃次数】
如果本文对你有帮助的话记得给一乐点个赞哦,感谢!
发表评论