题目描述:
给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a ,b ,c ,使得 a + b + c = 0 ?请找出所有和为 0 且 不重复 的三元组。
示例 1:
输入:nums = [-1,0,1,2,-1,-4] 输出:[[-1,-1,2],[-1,0,1]]
示例 2:
输入:nums = [] 输出:[]
示例 3:
输入:nums = [0] 输出:[]
思路描述:
先排序,保证有序,然后找到所有的三个元素的组合,再去重。
代码:
class Solution {public List<List<Integer>> threeSum(int[] nums) {int n=nums.length;Arrays.sort(nums);Set<List<Integer>> set=new HashSet<>();for(int i=0;i<n;i++){List<Integer> list=new LinkedList<>();int left=i+1;int right=n-1;while (left<right){if(nums[left]+nums[right]+nums[i]>0){right--;} else if (nums[left] + nums[right] + nums[i] < 0) {left++;}else{list.add(nums[i]);list.add(nums[left]);list.add(nums[right]);set.add(list);list=new LinkedList<>();left++;right--;}}}return new LinkedList<>(set);}
}