[アルゴリズムトレーニング-配列]leetcode13。3つの数値の合計(js)

トピックリンク:leetcode-cn.com/problems/3s…

トピックの説明

n個の整数を含む配列numsが与えられた場合、a + b + c = 0となるようなnumsに3つの要素a、b、cがあるかどうかを判断しますか?合計が0で、繰り返されないすべてのトリプルを見つけてください。

注:回答に重複するトリプルを含めることはできません。

  • 例1:

入力:nums = [-1,0,1,2、-1、-4]

出力:[[-1、-1,2]、[-1,0,1]]

  • 例2:

入力:nums = []

出力:[]

  • ヒント:

0 <= nums.length <= 3000

-105 <= nums [i] <= 105

問題解決

最適な解決策:最初に並べ替えてから、ダブルポインター移動方法を使用します。時間計算量o(n)

/**
 * @param {number[]} nums
 * @return {number[][]}
 */
var threeSum = function(nums) {
    // 对数组进行排序
    let arrSOrt = nums.sort((a,b) => a - b);
    // 结果数组
    let result = [];
    for (let i = 0; i<nums.length; i++) {
        // 去重
        if (i > 0 && arrSOrt[i] === arrSOrt [i - 1])
            continue;
        let left = i + 1;
        let right = nums.length - 1;
        while(left < right) {
            let sum = arrSOrt[i] + arrSOrt[left] + arrSOrt[right];
            if (sum === 0) {
                result.push([arrSOrt[i], arrSOrt[left], arrSOrt[right]]);
                // 去重
                while(left < right && arrSOrt[left] === arrSOrt[left+1]) left++;
                while(left < right && arrSOrt[right] === arrSOrt[right - 1]) right--;
                left++;
                right--;
            } else if (sum < 0) {
                left++;
            } else {
                right--;
            }
        }
    }
    return result;
};
复制代码

要約する

このトピックは無視して重複を排除するのは簡単ですが、一度に正しく書くのはまだ少し難しいです。

アルゴリズムの練習github:github.com/mengmengzp/…

おすすめ

転載: juejin.im/post/7083805639805255716