leetcode-45-跳跃游戏

先放完整代码

//给你一个非负整数数组 nums ,你最初位于数组的第一个位置。 
//
// 数组中的每个元素代表你在该位置可以跳跃的最大长度。 
//
// 你的目标是使用最少的跳跃次数到达数组的最后一个位置。 
//
// 假设你总是可以到达数组的最后一个位置。 
//
// 
//
// 示例 1: 
//
// 
//输入: nums = [2,3,1,1,4]
//输出: 2
//解释: 跳到最后一个位置的最小跳跃数是 2。
//     从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。
// 
//
// 示例 2: 
//
// 
//输入: nums = [2,3,0,1,4]
//输出: 2
// 
//
// 
//
// 提示: 
//
// 
// 1 <= nums.length <= 104 
// 0 <= nums[i] <= 1000 




//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public int jump(int[] nums) {
        int len = nums.length - 1;
        int sum = 0;
        int i = 0;
        while (len > 0) {
            if (nums[i] + i >= len) {
                sum++;
                len = i;
                i = 0;
                continue;
            }
            i++;
        }
        return sum;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

解释

解法比较简单,首先明确使用贪心算法,具体的贪心粗略:

1.每次找到最远的可以一步就到达右边边界的位置,记为k;很明显,想要找到位置k,只需要从左边开始遍历,找到nums[k] + [k] >= 边界len的即可;

2.找到此位置后,跳跃次数 +1,并且将边界len更新为k,即再次寻找可以一步到位置k的最远位置。

3.重复1,2,当k=0时,则为需要跳跃的次数

时间复杂度:O(n²)

空间复杂度:O(1)

注:最坏的情况就是[1,1,1,1,1]这种,需要遍历n²次

上一篇:python数据类型内置的方法


下一篇:Qt对于过长的字符串或者数据在 qDebug() << 会不输出。。。。。