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 26 27 28 29 30 31 32 33
| class Solution { public List<List<Integer>> threeSum(int[] nums) { Arrays.sort(nums); List<List<Integer>> result = new ArrayList<>(); int n = nums.length;
for (int i = 0; i < n - 2; i++) { if (i > 0 && nums[i] == nums[i - 1]) continue; int lP = i + 1; int rP = n - 1;
while (lP < rP) { int sum = nums[i] + nums[lP] + nums[rP]; if (sum == 0){ result.add(Arrays.asList(nums[i], nums[lP], nums[rP])); while (lP < rP && nums[lP] == nums[lP+1]) lP++; while (lP < rP && nums[rP] == nums[rP-1]) rP--; lP++; rP--; } else if (sum < 0){ lP++; } else { rP--; } }
}
return result; } }
|