Skip to content

Commit 44eaaa6

Browse files
committed
solve: 3sum
1 parent 99e7ce5 commit 44eaaa6

File tree

1 file changed

+49
-0
lines changed

1 file changed

+49
-0
lines changed

3sum/evan.js

Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
/**
2+
* @param {number[]} nums
3+
* @return {number[][]}
4+
*/
5+
var threeSum = function (nums) {
6+
const sorted = nums.sort((a, b) => a - b);
7+
const result = [];
8+
9+
for (let i = 0; i < sorted.length; i++) {
10+
const fixedNumber = sorted[i];
11+
const previousFixedNumber = sorted[i - 1];
12+
13+
if (fixedNumber === previousFixedNumber) {
14+
continue;
15+
}
16+
17+
let [leftEnd, rightEnd] = [i + 1, sorted.length - 1];
18+
19+
while (leftEnd < rightEnd) {
20+
const sum = fixedNumber + sorted[leftEnd] + sorted[rightEnd];
21+
22+
if (sum === 0) {
23+
result.push([sorted[leftEnd], sorted[rightEnd], sorted[i]]);
24+
25+
while (
26+
sorted[leftEnd + 1] === sorted[leftEnd] ||
27+
sorted[rightEnd - 1] === sorted[rightEnd]
28+
) {
29+
if (sorted[leftEnd + 1] === sorted[leftEnd]) {
30+
leftEnd += 1;
31+
}
32+
33+
if (sorted[rightEnd - 1] === sorted[rightEnd]) {
34+
rightEnd -= 1;
35+
}
36+
}
37+
38+
leftEnd += 1;
39+
rightEnd -= 1;
40+
} else if (sum < 0) {
41+
leftEnd += 1;
42+
} else {
43+
rightEnd -= 1;
44+
}
45+
}
46+
}
47+
48+
return result;
49+
};

0 commit comments

Comments
 (0)