Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
40 changes: 40 additions & 0 deletions merge-intervals/robinyoon-dev.js
Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🏷️ 알고리즘 패턴 분석

  • 패턴: Sorting
  • 설명: 이 코드는 먼저 intervals를 정렬한 후, 정렬된 배열을 순회하며 겹치는 구간을 병합하는 방식으로 문제를 해결한다. 정렬이 핵심 단계로 사용되어 병합 과정을 용이하게 만든다.

📊 시간/공간 복잡도 분석

복잡도
Time O(n log n)
Space O(n)

피드백: 배열 정렬에 O(n log n) 시간이 소요되고, 결과 저장을 위해 O(n) 공간이 필요합니다. 반복문은 O(n)입니다.

개선 제안: 현재 구현이 적절해 보입니다.

💡 풀이에 시간/공간 복잡도를 주석으로 남겨보세요!

Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
/**
* @param {number[][]} intervals
* @return {number[][]}
*/
var merge = function (intervals) {

let result = [];

let sortedIntervals = intervals.toSorted((a, b) => a[0] - b[0]);

for (let interval of sortedIntervals) {

if (result.length == 0) {
result.push(interval);
continue;
}

let intervalStart = interval[0];
let intervalEnd = interval[1];

let lastItemInResult = result[result.length - 1];

let start = lastItemInResult[0];
let end = lastItemInResult[1];

let isIntervalStartInRange = intervalStart >= start && intervalStart <= end;

if (isIntervalStartInRange) {
if (intervalEnd > end) {
result[result.length - 1][1] = intervalEnd;
}
} else {
result.push(interval);
}

}

return result;

};
17 changes: 17 additions & 0 deletions missing-number/robinyoon-dev.js
Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🏷️ 알고리즘 패턴 분석

  • 패턴: Sorting
  • 설명: 이 코드는 배열을 정렬한 후 인덱스와 값이 일치하는지 차례로 검사하여 누락된 숫자를 찾는 방식으로, 정렬 패턴이 사용되었습니다.

📊 시간/공간 복잡도 분석

복잡도
Time O(n log n)
Space O(1)

피드백: 배열 정렬에 O(n log n) 시간이 소요되고, 이후 순차 검사로 O(n)입니다. 공간은 정렬을 위한 제자리 정렬이 아니면 추가 공간이 필요할 수 있으나, 여기서는 sort의 공간 복잡도 고려.

개선 제안: 현재 구현이 적절해 보입니다.

💡 풀이에 시간/공간 복잡도를 주석으로 남겨보세요!

Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
/**
* @param {number[]} nums
* @return {number}
*/
var missingNumber = function (nums) {

let n = nums.length + 1;
let sortedNums = nums.sort((a, b) => a - b);

for (let i = 0; i < n; i++) {
if (sortedNums[i] === i) {
continue;
} else {
return i;
}
}
};
Loading