560. Subarray Sum Equals K
Input:
nums = [1,1,1], k = 2
Output: 2class Solution {
public int subarraySum(int[] nums, int k) {
int sum = 0, result = 0;
Map<Integer, Integer> preS = new HashMap<Integer, Integer>();
preS.put(0,1);
for(int num: nums){
sum += num;
if(preS.containsKey(sum-k)){
result += preS.get(sum - k); // find how many preSum has value sum - k so that the right part sum is k.
}
// put prefix sum for the future
preS.put(sum, preS.getOrDefault(sum,0) + 1);
}
return result;
}
}Last updated
Was this helpful?