Skip to content

Commit 7c0329e

Browse files
Longest subarray sum equals K
1 parent 5694de8 commit 7c0329e

File tree

2 files changed

+64
-0
lines changed

2 files changed

+64
-0
lines changed
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
package leetcode.medium;
2+
3+
import java.util.HashMap;
4+
import java.util.Map;
5+
6+
public class LongestSubarraySumEqualsK {
7+
8+
int longestSubarray(int[] arr, int k) {
9+
Map<Integer, Integer> sumSeenIndexMap = new HashMap<>();
10+
int res = 0;
11+
int prefSum = 0;
12+
13+
for (int i = 0; i < arr.length; ++i) {
14+
prefSum += arr[i];
15+
16+
// If prefixSum - k exists in the map then there exist such
17+
// subarray from (index of previous prefix + 1) to i.
18+
if (sumSeenIndexMap.containsKey(prefSum - k))
19+
res = Math.max(res, i - sumSeenIndexMap.get(prefSum - k));
20+
21+
// Store only first occurrence index of prefSum
22+
if (!sumSeenIndexMap.containsKey(prefSum))
23+
sumSeenIndexMap.put(prefSum, i);
24+
}
25+
26+
return res;
27+
}
28+
29+
}
Lines changed: 35 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
package leetcode.medium;
2+
3+
import org.junit.jupiter.api.Test;
4+
5+
import static org.junit.jupiter.api.Assertions.*;
6+
7+
class LongestSubarraySumEqualsKTest {
8+
9+
private final LongestSubarraySumEqualsK longestSubarraySumEqualsK;
10+
11+
LongestSubarraySumEqualsKTest() {
12+
longestSubarraySumEqualsK = new LongestSubarraySumEqualsK();
13+
}
14+
15+
@Test
16+
void testLongestSubarray1() {
17+
int[] nums = {1, -1, 5, -2, 3};
18+
int k = 3;
19+
assertEquals(2, longestSubarraySumEqualsK.longestSubarray(nums, k));
20+
}
21+
22+
@Test
23+
void testLongestSubarray2() {
24+
int[] nums = {-2, -1, 2, 1};
25+
int k = 1;
26+
assertEquals(2, longestSubarraySumEqualsK.longestSubarray(nums, k));
27+
}
28+
29+
@Test
30+
void testLongestSubarray3() {
31+
int[] nums = {10, 2, 2, 7, 8 , 1, 1, 1, 1, -10};
32+
int k = 4;
33+
assertEquals(4, longestSubarraySumEqualsK.longestSubarray(nums, k));
34+
}
35+
}

0 commit comments

Comments
 (0)