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];
}
반응형