개발자 톡

연습문제 톡 [HSAT 4회 정기 코딩 인증평가 기출] 통근버스 출발 순서 검증하기

JS

등록일
2024-11-13 13:08:52
조회수
114
작성자
vavoya6324

어떤 방식으로 해도 배열을 탐색하면서 다시 특정 배열을 탐색해야하는데, 이것은 최악의 경우 O(n^2)이 나올꺼라고 판단됩니다.


그리고 코테에서는 최악의 경우 또한 고려해서 문제를 만들었을 것이 분명하다고 생각하기에, 그냥 항시 O(n^2)이 나오는 코드로 작성했습니다


class List {
    constructor(length) {
        // 편의를 위해 배열 0 은 비워두기
        // [0] => index(v) 보다 큰 것을 찾아야하는 개수
        // [1] => index(v) 보다 작은 것을 찾아야하는 개수
        // [1] 이 만족되면 - 시키고 result에 개수 추가
        this.list = Array.from({length}, () => [0,0]);
        this.result = 0
    }

    add(value) {
        // 신규 값 추가
        // 이것보다 작은 것에 대해서 탐색 후, 해당 값의 [0] 값을 [1] 로 더해주기, [0] 을 제거하는게 아님
        // 이것보다 큰 값에 대해서 탐색 후, 해당 값의 [1] 값을 result 로 더해주기, [1] 을 제거하는게 아님
        // 따라서 기본적으로 배열을 전부 탐색하는 건 어쩔 수 없다.
        // 기본 배열 탐색이 O(n), 탐색 때 마다 List를 탐색해야하니 이것도 O(n), 결국 시간복잡도는 O(n^2)
        this.list.forEach((_, currentValue) => {
            if (currentValue < value) {
                // 1 < 2 를 만족하는 수열이 this.list[currentValue][0] 만큼 새로 생겼으니, 그것을 [1]에 추가
                this.list[currentValue][1] += this.list[currentValue][0]
            }
            else if (currentValue > value) {
                // 1 > 3 을 만족하는 수열이 this.list[currentValue][1] 만큼 새로 생겼으니, 그것을 result 에 추가
                this.result += this.list[currentValue][1]
            }
            else if (currentValue === value) {
                // 같으면 그냥 추가
                this.list[currentValue][0]++
            }
            else {
                // 그 외에는 무시
            }
        })
    }

    getResult() {
        return this.result
    }


}


// 입력처리
const fs = require('fs')
const input = fs.readFileSync('input.txt', 'utf8')
    .trim()
    .split(/\n+/)
const sequence = input[1].split(' ').map(Number)

const list = new List(5001)

sequence.forEach(v => {
    list.add(v)
})

console.log(list.getResult())

/*
수열을 앞에서 부터 읽어나감
특정 값보다 크거나 작은 것만 고려하면 됨, 1 < 2, 1 > 3. 여기서 1 2 3 의 수열 완성을 위해서는 1하고 2, 3을 각각 비교하면 되기에 2, 3의 값은 저장할 필요가 없음
따라서 배열은 1의 값만을 저장하고, 현재까지 배열을 *순서* 대로 읽어나가서 몇 단계에 몇개의 부분 수열들이 대기 중인지만 기록
 */
#[HSAT_4회_정기_코딩_인증평가_기출]_통근버스_출발_순서_검증하기
#js

이 카테고리의 톡 더보기