https://www.acmicpc.net/problem/3584
3584번: 가장 가까운 공통 조상
루트가 있는 트리(rooted tree)가 주어지고, 그 트리 상의 두 정점이 주어질 때 그들의 가장 가까운 공통 조상(Nearest Common Anscestor)은 다음과 같이 정의됩니다. 두 노드의 가장 가까운 공통 조상은, 두
www.acmicpc.net
문제
루트가 있는 트리(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 이하의 정수로 이름 붙여집니다.
테스트 케이스의 마지막 줄에 가장 가까운 공통 조상을 구할 두 노드가 주어집니다.
출력
각 테스트 케이스 별로, 첫 줄에 입력에서 주어진 두 노드의 가장 가까운 공통 조상을 출력합니다.
예제 입력 1
2
16
1 14
8 5
10 16
5 9
4 6
8 4
4 10
1 13
6 15
10 11
6 7
10 2
16 3
8 1
16 12
16 7
5
2 3
3 4
3 1
1 5
3 5
예제 출력 1
4
3
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.LinkedList;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws Exception{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st;
// t 입력
int t = Integer.parseInt(br.readLine());
for (int test_case = 0; test_case < t; test_case++) {
// n 입력
int n = Integer.parseInt(br.readLine());
// 노드 정보 넣을 배열
int[] arr = new int[n + 1];
// A, B 입력 후 arr에 입력
for (int i = 0; i < n - 1; i++) {
st = new StringTokenizer(br.readLine());
int a = Integer.parseInt(st.nextToken());
int b = Integer.parseInt(st.nextToken());
arr[b] = a;
}
// 공통 조상을 구할 두 노드 입력
st = new StringTokenizer(br.readLine());
int num1 = Integer.parseInt(st.nextToken());
int num2 = Integer.parseInt(st.nextToken());
// num1의 조상을 담을 LinkedList
LinkedList<Integer> list = new LinkedList<>();
arr[0] = num1;
int i = 0;
// 루트 노드를 찾을 때까지 linkedlist에 num1의 조상을 모두 넣는다.
while(arr[i] != 0) {
list.add(arr[i]);
i = arr[i];
}
// num2의 조상들을 확인하며, list에 있는지 확인한다.
int result = 0;
arr[0] = num2;
i = 0;
while(arr[i] != 0) {
if(list.contains(arr[i])) {
result = arr[i];
break;
}
i = arr[i];
}
// 출력
System.out.println(result);
}
}
}
'Problem Solving > BOJ' 카테고리의 다른 글
[백준, BOJ 15649] N과 M (1) (java) (0) | 2023.02.08 |
---|---|
[백준, BOJ 1244] 스위치 켜고 끄기 (java) (0) | 2023.02.08 |
[백준, BOJ 17391] 무한부스터 (java) (0) | 2023.02.06 |
[백준, BOJ 2178] 미로 탐색 (java) (0) | 2023.02.06 |
[백준, BOJ 1303] 전쟁 - 전투 (java) (0) | 2023.02.06 |