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<nums[start] )

{

return false;

}

if(end<nums.size() && target >nums[end])

{

return false;

}

if(start==end)

{

if(nums[start]==target)

{

return true;

}

else

{

return false;

}

}

while(start<=end)

{

int mid = (start+end)/2;

if(nums[mid]==target)

{

return true;

}

if(nums[mid]>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=nums[i];

if(first>0)

{

continue;

}

if(i>0 && nums[i] ==nums[i-1])

{

continue;

}

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

{

int second = nums[j];

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;

}

相关推荐
6Hzlia32 分钟前
【Hot 100 刷题计划】 LeetCode 739. 每日温度 | C++ 逆序单调栈
c++·算法·leetcode
良木生香1 小时前
【C++初阶】:STL——String从入门到应用完全指南(1)
c语言·开发语言·数据结构·c++·算法
XWalnut1 小时前
LeetCode刷题 day16
数据结构·算法·leetcode·链表·动态规划
寒秋花开曾相惜1 小时前
(学习笔记)4.1 Y86-64指令集体系结构(4.1.4 Y86-64异常&4.1.5 Y86-64程序)
开发语言·jvm·数据结构·笔记·学习
foundbug9993 小时前
基于混合整数规划的电池容量优化 - MATLAB实现
数据结构·算法·matlab
自我意识的多元宇宙3 小时前
树、森林——树与二叉树的应用(哈夫曼树的构造)
数据结构
memcpy04 小时前
LeetCode 2452. 距离字典两次编辑以内的单词【暴力;字典树】中等
算法·leetcode·职场和发展
水蓝烟雨4 小时前
2071. 你可以安排的最多任务数目
数据结构·链表
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【排序贪心】:魔法
c++·算法·贪心·csp·信奥赛·排序贪心·魔法
wearegogog1235 小时前
基于和差波束法的单脉冲测角MATLAB实现
人工智能·算法·matlab