class Solution {
public int numSubarraysWithSum(int[] nums, int goal) {
Map<Integer, Integer> d = new HashMap<Integer, Integer>();
d.put(0, 1);
int ans = 0;
int cur_sum = 0;
for (int i = 0; i < nums.length; i++) {
cur_sum += nums[i];
ans += d.getOrDefault(cur_sum - goal, 0);
d.put(cur_sum, d.getOrDefault(cur_sum, 0) + 1);
}
return ans;
}
}