大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
原题链接
给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有和为 0 且不重复的三元组。
注意:答案中不可以包含重复的三元组。
示例 1:
输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
示例 2:
输入:nums = []
输出:[]
示例 3:
输入:nums = [0]
输出:[]
提示:
0 <= nums.length <= 3000
-105 <= nums[i] <= 105
题解
固定a,则 b + c == -a,由此可以想到先排序,然后利用双指针,时间复杂度O(n2)
class Solution {
public:
vector<vector<int>> threeSum(vector<int>& nums) {
sort(nums.begin(),nums.end());
for(int i = 0;i < nums.size();i ++)cout<<nums[i]<<" ";
vector<vector<int> >res;
for(int i = 0;i < nums.size();i ++){
if(i >= 1 && nums[i] == nums[i - 1])continue;
int tar = -nums[i];
for(int j = i + 1,r = nums.size() - 1;j < r;j ++){
if(j > i + 1 && nums[j] == nums[j - 1])continue;
while(r - 1 > j && nums[j] + nums[r - 1] >= tar)r --;
if(nums[j] + nums[r] == tar)res.push_back({
nums[i],nums[j],nums[r]});
}
}
return res;
}
};
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/168728.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...