class Solution {
public List<List<Integer>> threeSum(int[] nums) {
List<List<Integer>> res = new ArrayList<>();
int n = nums.length;
//剪枝,当数组小于三个时
if(n<3) return res;
Arrays.sort(nums);
for(int i=0;i<n;i++){
//如果都一个数就大于0,可以不继续了
if(nums[i]>0) break;
//保证去重
if(i>0 && nums[i] == nums[i-1]) continue;
//左右指针收敛数组
int l = i+1,r = n-1;
int tar = -nums[i];
while(l<r){
int tmp = nums[l] + nums[r];
if(tmp<tar) l++;
else if(tmp>tar) r--;
else{
res.add(Arrays.asList(nums[i],nums[l],nums[r]));
//保证去重
while(l<r && nums[l] == nums[l+1]) l++;
while(l<r && nums[r] == nums[r-1]) r--;
l++;
r--;
}
}
}
return res;
}
}
相关文章
- 11-26Offer II 007. 数组中和为 0 的三个数
- 11-26剑指offer24:二叉树中和为输入整数值的所有路径。(注意: 在返回值的list中,数组长度大的数组靠前)
- 11-26Easy | 剑指 Offer 57. 和为s的两个数字(有序数组)
- 11-26剑指offer_007 数组中和为0的三个数
- 11-26【剑指 Offer II】 007. 数组中和为 0 的三个数
- 11-26剑指 Offer II 007. 数组中和为 0 的三个数
- 11-26剑指Offer:面试题25——二叉树中和为某一值的路径(java实现)
- 11-26【Java】 剑指offer(56-1) 数组中只出现一次的两个数字
- 11-26【Java】 剑指offer(57-1) 和为s的两个数字
- 11-26剑指offer 数组中和为零的三个数Java