Medium
You are given an integer array nums of length n and a 2D array queries, where queries[i] = [li, ri].
For each queries[i]:
[li, ri] in nums.A Zero Array is an array where all elements are equal to 0.
Return true if it is possible to transform nums into a Zero Array after processing all the queries sequentially, otherwise return false.
A subset of an array is a selection of elements (possibly none) of the array.
Example 1:
Input: nums = [1,0,1], queries = [[0,2]]
Output: true
Explanation:
[0, 2] and decrement the values at these indices by 1.[0, 0, 0], which is a Zero Array.Example 2:
Input: nums = [4,3,2,1], queries = [[1,3],[0,2]]
Output: false
Explanation:
[1, 2, 3] and decrement the values at these indices by 1.[4, 2, 1, 0].[0, 1, 2] and decrement the values at these indices by 1.[3, 1, 0, 0], which is not a Zero Array.Constraints:
1 <= nums.length <= 1050 <= nums[i] <= 1051 <= queries.length <= 105queries[i].length == 20 <= li <= ri < nums.lengthpublic class Solution {
public boolean isZeroArray(int[] nums, int[][] queries) {
int n = nums.length;
int sum = 0;
for (int num : nums) {
sum += num;
}
if (sum == 0) {
return true;
}
int[] diff = new int[n + 1];
for (int[] q : queries) {
int low = q[0];
int high = q[1];
diff[low] -= 1;
if (high + 1 < n) {
diff[high + 1] += 1;
}
}
for (int i = 0; i < n; i++) {
if (i > 0) {
diff[i] += diff[i - 1];
}
nums[i] += diff[i];
sum += diff[i];
if (nums[i] > 0) {
return false;
}
}
return sum <= 0;
}
}