Skip to content

Commit 6fdca7f

Browse files
committed
3. 3Sum
1 parent 8deb5e5 commit 6fdca7f

File tree

1 file changed

+33
-0
lines changed

1 file changed

+33
-0
lines changed

3sum/whewchews.ts

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
function threeSum(nums: number[]): number[][] {
2+
let result: [number, number, number][] = [];
3+
const TARGET = 0;
4+
// TC: O(NlogN)
5+
nums.sort((a, b) => a - b);
6+
7+
for (let i = 0; i < nums.length - 2; i++) {
8+
if (i > 0 && nums[i] === nums[i - 1]) continue;
9+
10+
let left = i + 1;
11+
let right = nums.length - 1;
12+
13+
while (left < right) {
14+
let sum = nums[i] + nums[left] + nums[right];
15+
16+
if (sum === TARGET) {
17+
result.push([nums[i], nums[left], nums[right]]);
18+
while (nums[left] === nums[left + 1]) left++;
19+
while (nums[right] === nums[right - 1]) right--;
20+
left++;
21+
right--;
22+
} else if (sum < TARGET) {
23+
left++;
24+
} else {
25+
right--;
26+
}
27+
}
28+
}
29+
30+
return result;
31+
}
32+
// TC: O(n^2)
33+
// SC: O(n)

0 commit comments

Comments
 (0)