三数之和
class Solution {
public static List<List<Integer>> threeSum(int[] nums) {
Arrays.sort(nums);
List<List<Integer>> res = new ArrayList<>();
for (int i = 0; i < nums.length; i++) {
if (i != 0 && (nums[i] == nums[i - 1])) continue;
int k = nums.length - 1;
for (int j = i + 1; j < k; j++) {
if (j > i + 1 && (nums[j] == nums[j - 1])) continue;
while (j < k) {
while (j < k && (nums[i] + nums[j] + nums[k]) < 0) j++;
while (j < k && nums[i] + nums[j] + nums[k] > 0) k--;
if (j < k && nums[i] + nums[j] + nums[k] == 0) {
List<Integer> t = new ArrayList<>();
t.add(nums[i]);
t.add(nums[j]);
t.add(nums[k]);
res.add(t);
break;
}
}
}
}
return res;
}
}