-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathFourSum.java
25 lines (22 loc) · 839 Bytes
/
FourSum.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
public class FourSum {
public List<List<Integer>> fourSum(int[] nums, int target) {
Arrays.sort(nums);
final Set<List<Integer>> quadruplets = new HashSet<>();
for (int a = 0 ; a < nums.length - 3 ; a++) {
for (int b = a + 1 ; b < nums.length - 2 ; b++) {
for (int c = b + 1, d = nums.length - 1 ; c < d ; ) {
int sum = nums[a] + nums[b] + nums[c] + nums[d];
if (sum == target) quadruplets.add(List.of(nums[a], nums[b], nums[c++], nums[d--]));
else if (sum < target) c++;
else d--;
}
}
}
return new ArrayList<>(quadruplets);
}
}