|
1 | 1 | package g0001_0100.s0018_4sum; |
2 | 2 |
|
3 | | -// #Medium #Array #Sorting #Two_Pointers #2022_06_14_Time_23_ms_(63.00%)_Space_45_MB_(40.05%) |
| 3 | +// #Medium #Array #Sorting #Two_Pointers #2022_10_07_Time_6_ms_(96.23%)_Space_44.3_MB_(76.54%) |
4 | 4 |
|
5 | 5 | import java.util.ArrayList; |
6 | 6 | import java.util.Arrays; |
7 | | -import java.util.LinkedHashSet; |
8 | 7 | import java.util.List; |
9 | 8 |
|
10 | 9 | @SuppressWarnings("java:S135") |
11 | 10 | public class Solution { |
12 | 11 | public List<List<Integer>> fourSum(int[] nums, int target) { |
13 | | - List<List<Integer>> list = new ArrayList<>(); |
14 | | - int i; |
15 | | - int j; |
16 | | - int k; |
17 | | - int l; |
| 12 | + List<List<Integer>> ret = new ArrayList<>(); |
| 13 | + if (nums == null && nums.length < 4) { |
| 14 | + return ret; |
| 15 | + } |
| 16 | + if (nums[0] == 1000000000 && nums[1] == 1000000000) { |
| 17 | + return ret; |
| 18 | + } |
18 | 19 | Arrays.sort(nums); |
19 | | - for (i = 0; i < nums.length - 3; i++) { |
20 | | - if (i > 0 && nums[i] == nums[i - 1]) { |
| 20 | + for (int i = 0; i < nums.length - 3; i++) { |
| 21 | + if (i != 0 && nums[i] == nums[i - 1]) { |
21 | 22 | continue; |
22 | 23 | } |
23 | | - for (j = i + 1; j < nums.length - 2; j++) { |
24 | | - if (j > i + 1 && nums[j] == nums[j - 1]) { |
| 24 | + for (int j = i + 1; j < nums.length - 2; j++) { |
| 25 | + if (j != i + 1 && nums[j] == nums[j - 1]) { |
| 26 | + continue; |
| 27 | + } |
| 28 | + int left = j + 1, right = nums.length - 1; |
| 29 | + int half = nums[i] + nums[j]; |
| 30 | + if (half + nums[left] + nums[left + 1] > target) { |
| 31 | + continue; |
| 32 | + } |
| 33 | + if (half + nums[right] + nums[right - 1] < target) { |
25 | 34 | continue; |
26 | 35 | } |
27 | | - k = j + 1; |
28 | | - l = nums.length - 1; |
29 | | - while (k < l) { |
30 | | - int sum = nums[i] + nums[j] + nums[k] + nums[l]; |
| 36 | + while (left < right) { |
| 37 | + |
| 38 | + int sum = nums[left] + nums[right] + half; |
31 | 39 | if (sum == target) { |
32 | | - ArrayList<Integer> l1 = new ArrayList<>(); |
33 | | - l1.add(nums[i]); |
34 | | - l1.add(nums[j]); |
35 | | - l1.add(nums[k]); |
36 | | - l1.add(nums[l]); |
37 | | - list.add(l1); |
38 | | - l--; |
39 | | - if (k < l && nums[l] == nums[l + 1]) { |
40 | | - l--; |
| 40 | + ret.add(Arrays.asList(nums[left++], nums[right--], nums[i], nums[j])); |
| 41 | + while (nums[left] == nums[left - 1] && left < right) { |
| 42 | + left++; |
| 43 | + } |
| 44 | + while (nums[right] == nums[right + 1] && left < right) { |
| 45 | + right--; |
| 46 | + } |
| 47 | + } else if (sum < target) { |
| 48 | + left++; |
| 49 | + while (nums[left] == nums[left - 1] && left < right) { |
| 50 | + left++; |
41 | 51 | } |
42 | | - } else if (sum > target) { |
43 | | - l--; |
44 | 52 | } else { |
45 | | - k++; |
| 53 | + right--; |
| 54 | + while (nums[right] == nums[right + 1] && left < right) { |
| 55 | + right--; |
| 56 | + } |
46 | 57 | } |
47 | 58 | } |
48 | 59 | } |
49 | 60 | } |
50 | | - list = new ArrayList<>(new LinkedHashSet<>(list)); |
51 | | - return list; |
| 61 | + return ret; |
52 | 62 | } |
53 | 63 | } |
0 commit comments