LeetCode-in-Java

3468. Find the Number of Copy Arrays

Medium

You are given an array original of length n and a 2D array bounds of length n x 2, where bounds[i] = [ui, vi].

You need to find the number of possible arrays copy of length n such that:

  1. (copy[i] - copy[i - 1]) == (original[i] - original[i - 1]) for 1 <= i <= n - 1.
  2. ui <= copy[i] <= vi for 0 <= i <= n - 1.

Return the number of such arrays.

Example 1:

Input: original = [1,2,3,4], bounds = [[1,2],[2,3],[3,4],[4,5]]

Output: 2

Explanation:

The possible arrays are:

Example 2:

Input: original = [1,2,3,4], bounds = [[1,10],[2,9],[3,8],[4,7]]

Output: 4

Explanation:

The possible arrays are:

Example 3:

Input: original = [1,2,1,2], bounds = [[1,1],[2,3],[3,3],[2,3]]

Output: 0

Explanation:

No array is possible.

Constraints:

Solution

public class Solution {
    public int countArrays(int[] original, int[][] bounds) {
        int low = bounds[0][0];
        int high = bounds[0][1];
        int ans = high - low + 1;
        for (int i = 1; i < original.length; ++i) {
            int diff = original[i] - original[i - 1];
            low = Math.max(low + diff, bounds[i][0]);
            high = Math.min(high + diff, bounds[i][1]);
            ans = Math.min(ans, high - low + 1);
        }
        return Math.max(ans, 0);
    }
}