Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- SWEA
- 백준
- 수 만들기
- 탄막
- 단어 수학
- 3344
- 탄막 이동
- 3273
- 그리디알고리즘
- c#
- 탄막 스킬 범위
- 2020 KAKAO BLIND RECRUITMENT
- 알고리즘 목차
- 알고리즘
- MySQL
- 문자열 압축
- 18249
- 윈도우
- 강의실2
- AI Hub
- 자료구조 목차
- 마우스 따라다니기
- 원형
- 회의실 배정
- 유니티
- 영상 프레임 추출
- mysqld.sock
- 토글 그룹
- 우분투
- 걷는건귀찮아
Archives
- Today
- Total
와이유스토리
[트리(LCA)] 백준 11437 LCA C++ 본문
https://www.acmicpc.net/problem/11437
#include <iostream>
#include <vector>
#define size 50001
using namespace std;
vector<int> graph[size];
int level[size];
int dp[size][30]; // log2(50001)
int visited[size];
int n;
void dfs(int v, int depth) {
visited[v] = 1;
level[v] = depth;
for (auto i : graph[v]) {
if (!visited[i]) {
dp[i][0] = v; // dp[자식 노드][0] = 부모 노드
dfs(i, depth + 1);
}
}
}
void initTable() { // i의 2^j번째 조상 = (i의 2^(j-1)번째 조상)의 2^(j-1)번째 조상
for (int j = 1; j < 30; j++) {
for (int i = 1; i <= n; i++) {
dp[i][j] = dp[dp[i][j - 1]][j - 1]; // dp[i][j] := i의 2^j번째 조상
}
}
}
int lca(int u, int v) {
if (level[u] < level[v]) swap(u, v);
int diff = level[u] - level[v];
int i = 0;
while(diff) { // 레벨 차이
if (diff & 1) u = dp[u][i];
diff >>= 1;
i++;
}
if (u == v) return u; // 같은 레벨
for (int i = 29; i >= 0; i--) { // 조상이 다르면 노드들을 조상 노드로 변경하여 다시 찾음
if (dp[u][i] != dp[v][i]) u = dp[u][i], v = dp[v][i];
}
return dp[u][0]; // u!=v (u와 v의 부모 노드 같음)
}
int main() {
ios_base::sync_with_stdio(0);
cin.tie(NULL); cout.tie(NULL);
int m, a, b;
cin >> n;
for (int i = 0; i < n - 1; i++) {
cin >> a >> b;
graph[a].push_back(b);
graph[b].push_back(a);
}
dfs(1, 0);
initTable();
cin >> m;
for(int i = 0; i < m; i++) {
cin >> a >> b;
cout << lca(a, b) << "\n";
}
}
'코딩테스트 > 그래프|트리' 카테고리의 다른 글
[그래프(플로이드)] 백준 11404 플로이드 C++ (0) | 2022.01.27 |
---|---|
[그래프(다익스트라)] 백준 1753 최단경로 C++ (0) | 2022.01.27 |
[DFS 백트래킹] 백준 19236 청소년 상어 C++ (0) | 2022.01.23 |
[DFS 중복조합] 백준 15652 N과 M(4) / 15658 N과 M(8) C++ (0) | 2022.01.22 |
[DFS 중복순열] 백준 15651 N과 M(3) / 15656 N과 M(7) C++ (0) | 2022.01.22 |
Comments