トピックリンク: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/…