Medium
You are given an integer array nums and an array queries where queries[i] = [vali, indexi].
For each query i, first, apply nums[indexi] = nums[indexi] + vali, then print the sum of the even values of nums.
Return an integer array answer where answer[i] is the answer to the ith query.
Example 1:
Input: nums = [1,2,3,4], queries = [[1,0],[-3,1],[-4,0],[2,3]]
Output: [8,6,2,4]
Explanation: At the beginning, the array is [1,2,3,4].
After adding 1 to nums[0], the array is [2,2,3,4], and the sum of even values is 2 + 2 + 4 = 8.
After adding -3 to nums[1], the array is [2,-1,3,4], and the sum of even values is 2 + 4 = 6.
After adding -4 to nums[0], the array is [-2,-1,3,4], and the sum of even values is -2 + 4 = 2.
After adding 2 to nums[3], the array is [-2,-1,3,6], and the sum of even values is -2 + 6 = 4.
Example 2:
Input: nums = [1], queries = [[4,0]]
Output: [0]
Constraints:
1 <= nums.length <= 104-104 <= nums[i] <= 1041 <= queries.length <= 104-104 <= vali <= 1040 <= indexi < nums.lengthpublic class Solution {
public int[] sumEvenAfterQueries(int[] nums, int[][] queries) {
int[] result = new int[queries.length];
int res = 0;
for (int num : nums) {
res += (num & 1) == 0 ? num : 0;
}
int k = 0;
for (int[] query : queries) {
res -= (nums[query[1]] & 1) == 0 ? nums[query[1]] : 0;
nums[query[1]] += query[0];
if ((nums[query[1]] & 1) == 0) {
res += nums[query[1]];
}
result[k++] = res;
}
return result;
}
}