固定一个数i,然后寻找其中的两个数。
- 为什么要先排序:排序之后才可以更好的去重,例如如果答案会是[-1, 0, 1] 排序之后返回的结果天然就是有序的,不需要额外区分。i就是-1,left从0开始,避免了重复的问题;
- 为什么遇到跟上一个数相同的要跳过:例如[-1, -1, -1, 0, 1],此时无论用哪一个-1结果都是相同的,因此用最后一个。
- 为什么 sum为0时,要L++,R--:因为sum=0时,说明找到了一个符合条件的数,二者同时移动去找下一组合适的解(只移动一边的话,只会导致sum大于0或者小于0,永远不会等于0,无意义)。
java
class Solution {
public List<List<Integer>> threeSum(int[] nums) {
// 排序
Arrays.sort(nums);
List<List<Integer>> res = new ArrayList<>();
int len = nums.length;
for(int i = 0;i<len;i++){
if(i > 0 && nums[i] == nums[i-1]) continue;
int left = i+1;
int right = len - 1;
while(left < right){
int sum = nums[i] + nums[left] + nums[right];
if(sum == 0){
res.add(Arrays.asList(nums[i], nums[left], nums[right]));
while(left < right && nums[left] == nums[left + 1]){
left++;
}
while(left < right && nums[right] == nums[right - 1]){
right-- ;
}
left++;
right--;
}else if(sum > 0){
right--;
}else{
left++;
}
}
}
return res;
}
}