Skip to content

Commit 71dd53c

Browse files
Add BinarySubarrayWithSumGoal class with hashmap approach
1 parent cdfdea9 commit 71dd53c

File tree

1 file changed

+26
-0
lines changed

1 file changed

+26
-0
lines changed
Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
class BinarySubarrayWithSumGoal { //Hashmap approach
2+
public int numSubarraysWithSum(int[] nums, int goal) {
3+
int n = nums.length;
4+
int[] prefixSum = new int[n];
5+
6+
prefixSum[0] = nums[0];
7+
for(int i = 1; i<n; i++){
8+
prefixSum[i] = prefixSum[i-1] + nums[i];
9+
}
10+
11+
int count = 0;
12+
13+
Map<Integer, Integer> map = new HashMap<>();
14+
map.put(0, 1);
15+
16+
for(int i = 0; i<n; i++){
17+
int remaining = prefixSum[i] - goal;
18+
if(map.containsKey(remaining)){
19+
count += map.get(remaining);
20+
}
21+
map.put(prefixSum[i], map.getOrDefault(prefixSum[i], 0) + 1);
22+
}
23+
24+
return count;
25+
}
26+
}

0 commit comments

Comments
 (0)