Skip to content

Commit c59745f

Browse files
committed
add: DaleStudy#241 3sum
1 parent 968a90a commit c59745f

File tree

1 file changed

+36
-0
lines changed

1 file changed

+36
-0
lines changed

3sum/sukyoungshin.ts

Lines changed: 36 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
function threeSum(nums: number[]): number[][] {
2+
nums.sort((a, b) => a - b);
3+
const result: number[][] = [];
4+
const target = 0;
5+
6+
for (let i = 0; i < nums.length - 2; i++) {
7+
// 중복된 시작 숫자는 건너뛰기
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+
const sum = nums[i] + nums[left] + nums[right];
15+
16+
if (sum === target) {
17+
result.push([nums[i], nums[left], nums[right]]);
18+
19+
// 중복된 left 값 건너뛰기
20+
while (left < right && nums[left] === nums[left + 1]) left++;
21+
// 중복된 right 값 건너뛰기
22+
while (left < right && nums[right] === nums[right - 1]) right--;
23+
24+
// 다음 조합 시도
25+
left++;
26+
right--;
27+
} else if (sum < 0) {
28+
left++;
29+
} else {
30+
right--;
31+
}
32+
}
33+
}
34+
35+
return result;
36+
};

0 commit comments

Comments
 (0)