三数之和
题目
给你一个包含 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
Related Topics
数组
双指针
排序
解题思路
代码实现
class Solution {
public static List<List<Integer>> threeSum(int[] nums) {
// 1、创建ans记录符合三数之和结果集
List<List<Integer>> ans = new ArrayList<>();
// 2、排除特殊情况
int length = nums.length;
if (nums == null || length < 3) return -1;
// 3、普通情况的处理
// 3.1、先排序
Arrays.sort(nums);
// 3.2、确定一个nums[i]值,在该值右侧进行取值验算是否符合三数之和
for (int i = 0; i < length; i++) {
// nums[i]若大于0,则排序后右侧值与其相加必大于0
if (nums[i] > 0) break;
// 去重
if (i > 0 && nums[i] == nums[i - 1]) continue;
// 标记左右侧值
int L = i + 1;
int R = length - 1;
// 找出符合三数之和的结果集
while (L < R) {
// 标记三数之和
int sum = nums[i] + nums[L] + nums[R];
// 若符合条件,添加至结果集中
if (sum = 0) {
ans.add(Arrays.asList(nums[i],nums[L],nums[R]));
// 去重
while (L < R && nums[L] == nums[L + 1]) L++;
while (L < R && nums[R] == nums[R - 1]) R--;
L++;
R--;
}
else if (sum < 0) L++;
else if (sum > 0) R--
}
}
return ans;
}
}
本文来自博客园,作者:软件工程师蜗小牛,转载请注明原文链接:https://www.cnblogs.com/SoftwareEngineerWXN/p/15502340.html

浙公网安备 33010602011771号