题目:三数之和
给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != j、i != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请你返回所有和为 0 且不重复的三元组。
注意:答案中不可以包含重复的三元组。
方案一:双指针+思维(去重)
class Solution {
public:
vector<vector<int>> threeSum(vector<int>& nums) {
vector<vector<int>> ans;
sort(nums.begin(),nums.end());
for(int i=0;i<nums.size();i++)
{
if(i&&nums[i]==nums[i-1])
continue;
//由于是相同数字
//现在遍历的后两个数的范围,是最开始那个遍历的子集,直接跳过
int j=i+1,k=nums.size()-1,target=-nums[i];
while(j<k)
{
if(nums[j]+nums[k]>target)
{
k--;
}
else if(nums[j]+nums[k]<target)
{
j++;
}
else if(nums[j]+nums[k]==target)
{
vector<int>tmp;
tmp.push_back(nums[i]);
tmp.push_back(nums[j]);
tmp.push_back(nums[k]);
ans.push_back(tmp);
int x1=nums[j];
int x2=nums[k];
while(j<nums.size()&&nums[j]==x1)
j++;
while(k>=0&&nums[k]==x2)
k--;
}
}
}
//枚举第一个数
return ans;
}
};