# [LeetCode] 3Sum

Given an array S of n integers, are there elements abc in S such that a + b + c = 0? Find all unique triplets in the array which gives the sum of zero.

Note:

• Elements in a triplet (a,b,c) must be in non-descending order. (ie, a ≤ b ≤ c)
• The solution set must not contain duplicate triplets.

    For example, given array S = {-1 0 1 2 -1 -4},

A solution set is:
(-1, 0, 1)
(-1, -1, 2)

public class Solution {
List<List<Integer>> ret = new ArrayList<List<Integer>>();

public List<List<Integer>> threeSum(int[] nums) {
if (nums == null || nums.length < 3)
return ret;
Arrays.sort(nums);

int len = nums.length;
for (int i = 0; i < len - 2; i++) {
//exclude duplicates
if (i > 0 && nums[i] == nums[i-1])
continue;
twoSum(nums, i + 1, len - 1, 0 - nums[i]);
}
return ret;
}

public void twoSum(int[] nums, int l, int r, int target) {
while (l < r) {
if (nums[l] + nums[r] == target) {
List<Integer> ans = new ArrayList<Integer>();

while (l < r && nums[l] == nums[l+1])
l++;
while (l < r && nums[r] == nums[r-1])
r--;
l++;
r--;
} else if (nums[l] + nums[r] < target)
l++;
else
r--;
}
}
}


• 本文已收录于以下专栏：

## 【LeetCode】3Sum 解题报告

• ljiabin
• 2014年10月30日 16:00
• 27165

## leetcode-java.T015_3Sum---给定一个n个元素的数组，是否存在a，b，c三个元素，使用得a+b+c=0，找出所有符合这个条件的三元组

package leetcode.T015_3Sum; import java.util.ArrayList; import java.util.Arrays; import java.util.H...

## 【LeetCode016-017算法/编程练习C++】3Sum Closest,九宫格输入法//Sort函数

LeetCode十六和十七题
• zmdsjtu
• 2017年01月04日 11:59
• 565

## 【LeetCode014-015算法/编程练习C++】最长共同前缀，3Sum(和为0) //用到了map的自动排序

LeetCode14和15题
• zmdsjtu
• 2016年12月30日 17:28
• 412

## 《LeetBook》leetcode题解(16):3Sum Closest [M]

16. 3Sum Closest [M]Given an array S of n integers, find three integers in S such that the sum is cl...

## 3Sum leetcode

Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all ...

## [LeetCode 解题报告]015. 3Sum

Description: Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0...

## Leetcode--3Sum

Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all ...

举报原因： 您举报文章：[LeetCode] 3Sum 色情 政治 抄袭 广告 招聘 骂人 其他 (最多只允许输入30个字)