1.题目描述
2.题目链接
LCR 007. 三数之和 - 力扣(LeetCode)
3.题目代码
import java.util.*;
class Solution {
public List<List<Integer>> threeSum(int[] nums) {
Arrays.sort(nums);
int temp=nums.length-1;
Set<List<Integer>> set=new HashSet<>();
while(temp>1){
int left=0,right=temp-1;
while(left<right){
if(nums[left]+nums[right]+nums[temp]==0){
List<Integer> row=Arrays.asList(nums[left],nums[right],nums[temp]);
set.add(row);
left++;right--;
}
else if(nums[left]+nums[right]+nums[temp]>0){
right--;
}else{
left++;
}
}
temp--;
}
return new ArrayList<>(set);
}
}
4.解题思路
这道题我们用的依然还是双指针+定数指针的解题思路,和前面我记录的有效三角形的个数的OJ题目一样,只需要定义定数指针在数组的最后一个元素上,再在剩余数组的边界定义两个指针,根据单调性来进行指针的移动即可。
5.代码细节
1)类型转换
因为我们为了方便去重,定义的是set,而题目中的泛型要求我们返回List<List<Integer>>,所以我们在定义完set之后:
Set<List<Integer>> set = new HashSet<>();
还需要在最后转换类型:
return new ArrayList<>(set);
2)构造动态三元组
创建动态列表存储三元组:
List<Integer> row=Arrays.asList(nums[left],nums[right],nums[temp]);
3)找到三元组后的指针移动逻辑
在找到1个三元组并且存入set后,我们需要移动双指针:left--,right++。
为什么呢?
因为我们需要寻找下一个符合条件的三元组,也就是寻找下一个满足nums[left]+nums[right]+nums[temp]==0的三元组,但是如果移动单个指针,等式的平衡会被打破,左边一定不会等于右边,只有同时移动双指针,才有可能重新满足不等式。