15. 3Sum 发表于 2022-01-05 1234567891011121314151617181920212223242526272829303132333435class Solution { public List<List<Integer>> threeSum(int[] nums) { List<List<Integer>> resultList = new ArrayList<>(); Arrays.sort(nums); for (int i = 0; i < nums.length - 2; i++) { if (i > 0 && nums[i] == nums[i - 1]) { continue; } if (nums[i] > 0) { // 剪枝 break; } int j = i + 1, k = nums.length - 1; // 注意后续都处理 j 和 k 指针,不要误写为 i 和 j while (j < k) { int sum = nums[i] + nums[j] + nums[k]; // 注意该行放 while 循环里 if (sum < 0) { j++; } else if (sum > 0) { k--; } else { resultList.add(Arrays.asList(nums[i], nums[j++], nums[k--])); while (j < k && nums[j] == nums[j - 1]) { j++; } while (j < k && nums[k] == nums[k + 1]) { k--; } } } } return resultList; }} Reference15. 3Sum剑指 Offer II 007. 数组中和为 0 的三个数