ProgramSoliving

프로그래머스 : 트리 트리오 중간값 javascript

하이후에호 2021. 6. 26. 23:16
반응형

문제풀이

 

기본적으로 javascript는 코딩 테스트 문제를 푸는것에 적절한 언어가 아닙니다.

해당문제는 BFS탐색을 필요로하는 문제입니다. 

 

1. 임의이 node에서 가장먼 node를 구합니다. 그것을 x라고 하겠습니다.

2. x에서 가장 먼 노드를 구합니다. 그것을 y라고 하겠습니다.

이때 발견된 y가 2이상이라면 x - y의 길이를 반환합니다.

3. 발견된게 1개라면  1. 2. 를 진행하고 그래도 1개라면 distance -1 을 진행합니다.

// 트리의 지름을 구하는 방법은 그리디를 이용해서 풀수가 있다.
// 1. 임의의 노드 a 에서 가장 깊은 노드 b를 DFS or BFS를 이용해서 구한다.
// 2. b노드에서 가장깊은 노드 c를 찾으면  b-c가 트리의 지름이 된다.

class Queue {
    constructor() {
        this._q_size = 250000;
        this._arr = Array(250000);
        this.front = 0;
        this.rear = 0;
    }
    
    push(value) {
        this.rear = (this.rear + 1) % this._q_size;
        this._arr[this.rear] = value;
    }
    
    pop() {
        this.front = (this.front + 1) % this._q_size;
        return this._arr[this.front];
    }

    isEmpty() {
        return this.front === this.rear;
    }

    size() {
        return (this._q_size + this.rear - this.front) % this._q_size;
    }
}

// 한지점에서 트리의 지름과 같은 노드가 2개이상이면 그값이 max
// 아니면 -1 값이 정답.

function solution(n, edges) {
    // init Edge 작업
    // var Edge = Array(n + 1).fill().map(_ => []);
    var Edge = Array.from({length : n + 1},() => [])

    const size = edges.length;
    
    for(let i=0;i<size;i++) {
        const edge = edges[i];
        let a = parseInt(edge[0]);
        let b = parseInt(edge[1]);
        Edge[a].push(b);
        Edge[b].push(a);
    }
    
    // 정점 후보 노드
    let [index, count, distance] = FallNode(1, Edge, n);
    
    [index, count, distance] = FallNode(index, Edge, n);
    
    if(count >= 2)
        return distance;
    
    [index, count, distance] = FallNode(index, Edge, n);
    
    return count === 1 ? distance - 1 : distance;
    
}

function FallNode(node, Edge, n) {
    var q = new Queue();

    var visit = Array(n+1).fill(false);
    q.push(node);
    visit[node] = true;

    let distance = -1;
    let count = 0;
    let index;
    
    while(!q.isEmpty()) {
        ++distance;
        count = 0;
        let size = q.size();
        for(let i=0;i<size;i++) {
            var check = true;
            let cur = q.pop();
            let len = Edge[cur].length;
            for(let i=0;i<len;i++){
                let next = Edge[cur][i];
                if(visit[next])
                    continue;
                check = false;
                q.push(next);
                visit[next] = true;
            }
            
            if(check) {
                index = cur;
                count++;
            }
        }

    }
    return [index, count, distance];
}
반응형