15. 三数之和

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != kj != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

**注意:**答案中不可以包含重复的三元组。

示例 1:

复制代码
输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
解释:
nums[0] + nums[1] + nums[2] = (-1) + 0 + 1 = 0 。
nums[1] + nums[2] + nums[4] = 0 + 1 + (-1) = 0 。
nums[0] + nums[3] + nums[4] = (-1) + 2 + (-1) = 0 。
不同的三元组是 [-1,0,1] 和 [-1,-1,2] 。
注意,输出的顺序和三元组的顺序并不重要。

示例 2:

复制代码
输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0 。

示例 3:

复制代码
输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0 。

提示:

  • 3 <= nums.length <= 3000
  • -105 <= nums[i] <= 105

bool midFind(vector<int>& nums,int start,int end,int target)

{

if(start<nums.size() &&start>=0 && target<numsstart )

{

return false;

}

if(end<nums.size() && target >numsend)

{

return false;

}

if(start==end)

{

if(numsstart==target)

{

return true;

}

else

{

return false;

}

}

while(start<=end)

{

int mid = (start+end)/2;

if(numsmid==target)

{

return true;

}

if(numsmid>target)

{

end=mid-1;

}

else

{

start=mid+1;

}

}

return false;

}

vector<vector<int>> threeSum(vector<int>& nums) {

vector<vector<int>> vec;

set<vector<int>>ret;

sort(nums.begin(),nums.end());

for(int i=0;i<nums.size();i++)

{

int first=numsi;

if(first>0)

{

continue;

}

if(i>0 && numsi ==numsi-1)

{

continue;

}

for(int j=i+1;j<nums.size();j++)

{

int second = numsj;

int third = 0-first-second;

if(first+second>0)

{

continue;

}

if(midFind(nums,j+1,nums.size()-1,third))

{

vector<int>tmp={first,second,third};

sort(tmp.begin(),tmp.end());

ret.insert(tmp);

}

}

}

for(auto it :ret)

{

vec.push_back(it);

}

return vec;

}

相关推荐
小羊在睡觉5 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
3DVisionary5 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
好评笔记5 小时前
机器学习面试八股——常用损失函数
人工智能·深度学习·算法·机器学习·校招
weixin_468466855 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
sheeta19985 小时前
LeetCode 每日一题笔记 日期:2026.05.29 题目:3300. 最小元素
笔记·leetcode
_日拱一卒6 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM6 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro7 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort7 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域8 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法