문제

https://leetcode.com/problems/longest-consecutive-sequence/description/

nums 에서 가장 긴 연속으로 증가하는 부분 배열의 길이 구하기

풀이

아이디어

O(n)이기 때문에 정렬 방식은 불가능하다고 판단함. ⇒ 특별한 방법이 생각이 안나서 일일이 구간을 확인해 주는 방식을 시도했다. 배열을 순회할 때 빠르게 원소를 찾아야 하기 때문에 Set을 이용하기로 함.

코드

function longestConsecutive(nums: number[]): number {
    const numSet = new Set < number > (nums);
    let longest = 0;
 
    for (const startNum of numSet) {
        // 증가하는 구간의 시작점인 경우에만 검사한다. (같은 구간을 중복해서 탐색하는 것을 막기)
        // nums.length가 10000인 경우에 뜬 Time Limit Exceeded를 해결하기 위해 추가함...
        if (numSet.has(startNum - 1)) {
            continue;
        }
        let length = 1;
        let currNum = startNum + 1;
        while (numSet.has(currNum)) {
            length++;
            currNum++;
        }
        longest = Math.max(longest, length);
    }
 
    return longest;
}

시간 / 공간 복잡도

for loop 내부에 while loop가 있긴 하지만 증가하는 구간의 시작점일 때만 실행되기 때문에 (이걸 놓쳐서 시간 초과 났었다..) 각 원소에 접근하는 횟수는 결국 1번뿐. ⇒ 시간 복잡도는 **O(n)**이 된다.

Set을 만들기 위해 n만큼의 공간이 필요하므로 공간 복잡도는 **O(n)**이 된다.