Skip to content

给你一个包含 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
};

上次更新于: