45. Jump Game II

1. Description

You are given a 0-indexed array of integers nums of length n. You are initially positioned at index 0.
Each element nums[i] represents the maximum length of a forward jump from index i. In other words, if you are at index i, you can jump to any index (i + j) where:

  • 0 <= j <= nums[i] and
  • i + j < n

Return the minimum number of jumps to reach index n - 1. The test cases are generated such that you can reach index n - 1.

2. Example

Example 1

Input: nums = [2,3,1,1,4]
Output: 2
Explanation: The minimum number of jumps to reach the last index is 2. Jump 1 step from index 0 to 1, then 3 steps to the last index.

Example 2

Input: nums = [2,3,0,1,4]
Output: 2

3. Constraints

  • 1 <= nums.length <= $10^4$
  • 0 <= nums[i] <= 1000
  • It’s guaranteed that you can reach nums[n - 1].

4. Solutions

Greedy

n = nums.size()
Time complexity: O(n)
Space complexity: O(1)

class Solution {
public:
    int jump(const vector<int> &nums) {
        const int n = nums.size();
        int jump_count = 0, current_right_border = 0, next_right_border = nums[0];
        for (int i = 0; i < n - 1; ++i) {
            if (current_right_border >= n - 1) {
                break;
            }

            next_right_border = max(i + nums[i], next_right_border);
            if (i == current_right_border) {
                current_right_border = next_right_border;
                ++jump_count;
            }
        }

        return jump_count;
    }
};
comments powered by Disqus