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;

}

相关推荐
FONE_Platform1 分钟前
FONE食品饮料行业全面预算解决方案:构建韧性增长
人工智能·算法·全面预算·全面预算管理系统·企业全面预算
月明长歌11 分钟前
【码道初阶】【Leetcode94&144&145】二叉树的前中后序遍历(非递归版):显式调用栈的优雅实现
java·数据结构·windows·算法·leetcode·二叉树
DanyHope27 分钟前
《LeetCode 49. 字母异位词分组:哈希表 + 排序 全解析》
算法·leetcode·哈希算法·散列表
iAkuya29 分钟前
(leetcode) 力扣100 15轮转数组(环状替代)
数据结构·算法·leetcode
杰克尼32 分钟前
蓝桥云课-5. 花灯调整【算法赛】
java·开发语言·算法
.小墨迹32 分钟前
C++学习之std::move 的用法与优缺点分析
linux·开发语言·c++·学习·算法·ubuntu
wanghowie33 分钟前
01.02 Java基础篇|核心数据结构速查
java·开发语言·数据结构
努力学算法的蒟蒻40 分钟前
day38(12.19)——leetcode面试经典150
算法·leetcode·面试
搬砖魁首1 小时前
ZK-ALU-在有限域上实现乘法和除法
算法·zk·alu·域运算·算术逻辑单元·模乘·蒙哥马利模约简
iAkuya1 小时前
(leetcode)力扣100 17缺失的第一个正数(哈希)
算法·leetcode·哈希算法