반응형
문제
루트가 있는 트리(rooted tree)가 주어지고, 그 트리 상의 두 정점이 주어질 때 그들의 가장 가까운 공통 조상(Nearest Common Anscestor)은 다음과 같이 정의됩니다.
- 두 노드의 가장 가까운 공통 조상은, 두 노드를 모두 자손으로 가지면서 깊이가 가장 깊은(즉 두 노드에 가장 가까운) 노드를 말합니다.
예를 들어 15와 11를 모두 자손으로 갖는 노드는 4와 8이 있지만, 그 중 깊이가 가장 깊은(15와 11에 가장 가까운) 노드는 4 이므로 가장 가까운 공통 조상은 4가 됩니다.
루트가 있는 트리가 주어지고, 두 노드가 주어질 때 그 두 노드의 가장 가까운 공통 조상을 찾는 프로그램을 작성하세요
입력
첫 줄에 테스트 케이스의 개수 T가 주어집니다.
각 테스트 케이스마다, 첫째 줄에 트리를 구성하는 노드의 수 N이 주어집니다. (2 ≤ N ≤ 10,000)
그리고 그 다음 N-1개의 줄에 트리를 구성하는 간선 정보가 주어집니다. 한 간선 당 한 줄에 두 개의 숫자 A B 가 순서대로 주어지는데, 이는 A가 B의 부모라는 뜻입니다. (당연히 정점이 N개인 트리는 항상 N-1개의 간선으로 이루어집니다!) A와 B는 1 이상 N 이하의 정수로 이름 붙여집니다.
테스트 케이스의 마지막 줄에 가장 가까운 공통 조상을 구할 두 노드가 주어집니다.
출력
각 테스트 케이스 별로, 첫 줄에 입력에서 주어진 두 노드의 가장 가까운 공통 조상을 출력합니다.
#include <iostream>
#include <string.h>
#include <deque>
#include<queue>
#include<vector>
#include<map>
#include <algorithm>
using namespace std;
int parent[10001];
bool visit[10001];
int main(void)
{
int T;
cin >> T;
for (int t = 0; t < T; t++)
{
int N;
cin >> N;
for (int i = 1; i <= N; i++)
{
parent[i] = i;
visit[i] = 0;
}
for (int i = 0; i < N - 1; i++)
{
int a,b;
cin >> a >> b;
parent[b] = a;
}
int node1, node2;
cin >> node1 >> node2;
queue<int> que;
que.push(node1);
visit[node1] = true;
while (!que.empty())
{
int cur = que.front();
que.pop();
if (parent[cur] != cur)
{
visit[parent[cur]] = true;
que.push(parent[cur]);
}
}
queue<int> que2;
que2.push(node2);
while (!que2.empty())
{
int cur = que2.front();
que2.pop();
if (visit[cur])
{
cout << cur << endl;
break;
}
if (parent[cur] != cur)
{
que2.push(parent[cur]);
}
}
}
}
반응형
'Algorithm' 카테고리의 다른 글
백준 14002번 가장 긴 증가하는 부분 수열 4 (0) | 2020.09.17 |
---|---|
백준 9252번 LCS 2 (0) | 2020.09.16 |
백준 1655번 가운데를 말해요 (0) | 2020.09.16 |
백준 16967번 배열 복원하기 (0) | 2020.09.15 |
백준 1647번 도시 분할 계획 (0) | 2020.09.15 |