给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有满足条件且不重复的三元组。
注意: 答案中不可以包含重复的三元组。
示例:
给定数组 nums = [-1, 0, 1, 2, -1, -4],
满足要求的三元组集合为: [ [-1, 0, 1], [-1, -1, 2] ]
解答,这题应该更适合用双指针方法。首先应该先排序,然后定义三个指针,i,left, right
javascript
var threeSum = function (nums) {
const results = []
//first sor this array
nums.sort((a, b) => a-b)
//console.log(nums)
//for loop to have a i, left and right
for (let i = 0; i < nums.length; i++) {
if (nums[i] > 0) {
return results
}
//对a去重,这里是拿前一个和现在得相比,而不是和后一个相比,思考【-1,-1,2】这条数据
if (i > 0 && nums[i] === nums[i - 1]) {
continue;
}
let left = i + 1;
let right = nums.length - 1
while (left < right) {
const sum = nums[i] + nums[left] + nums[right]
if (sum > 0) {
//right --
right--
} else if (sum < 0) {
left++
} else {
//found
results.push([nums[i], nums[left], nums[right]])
//b and c 去重
//这里得去重不像a得去重,因为b和c有可能是一样得,所以对于b来说可以拿后面得来比较
while (left < right && nums[left+1] === nums[left]) {
left++
}
while (left < right && nums[right] === nums[right - 1]) {
right--
}
//同时收缩
left++
right--
}
}
}
return results
};