250x250
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
- 백준#BOJ#12865#평범한배낭
- 백준#BOJ#8012#한동이는영업사원
- 백준#boj#16932#모양만들기
- 백준#BOJ#14501#퇴사#브루트포스
- 백준#BOJ#2615#오목
- 백준#BOJ#1939#중량제한
- 백준#boj#12755
Archives
- Today
- Total
순간을 성실히, 화려함보단 꾸준함을
[ boj : 1595 ] 북쪽나라의 도로 본문
https://www.acmicpc.net/problem/1595
해설 : 이 문제는 엄청나게 유명한 웰논문제입니다. 그냥 트리의 지름을 찾는 문제이죠.
dfs 2번을 돌리면 답을 찾을 수 있다는 것이 증명이 되어있지만, 이번에는 tree dp 로 풀어보았습니다.
과정은 이렇습니다.
dfs를 돌리면서 부모-자식 간의 가중치를 return 시켜줍니다. 이때 루트노드까지 도달했을때는 넘겨받은 값들을 vector에 담아줍니다. 그러면 루트로부터 각 리프노드까지 거리가 얼마나 되는지 알 수 있겠죠?
그 vector를 sort 하여 2개를 뽑아줍니다. 이때 주의할 점은 정점이 단 2개만 존재할때는 0번 index만 뽑아오면 되고, 입력자체가 주어지지 않는 경우도 있더라구요. 이럴때 0을 출력해 주면 됩니다.
#include<bits/stdc++.h>
using namespace std;
int visit[10010],child[10010];
vector<pair<int,int>> v[10010];
vector<int> li;
int dfs(int x);
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr);
int x, y, w;
while (true) {
cin >> x;
if (cin.eof())break;
cin >> y >> w;
v[x].push_back({ y,w });
v[y].push_back({ x,w });
}
dfs(1);
sort(li.begin(), li.end(), [](const int& a, const int& b) {
return a > b;
});
if (li.size() >= 2)
cout << li[0] + li[1];
else if (li.size() == 1)
cout << li[0];
else
cout << 0;
return 0;
}
int dfs(int x)
{
visit[x] = 1;
for (int i = 0; i < v[x].size(); i++) {
if (!visit[v[x][i].first]) {
int ret = dfs(v[x][i].first) + v[x][i].second;
if (x == 1)
li.push_back(ret);
child[x] = max(child[x], ret);
}
}
return child[x];
}
'알고리즘,SQL > 백준,BOJ' 카테고리의 다른 글
[ boj : 17135 ] 캐슬 디펜스 (0) | 2021.09.20 |
---|---|
[ boj : 1253 ] 좋다 (0) | 2021.09.19 |
[ boj : 1231 ] 주식왕 동호 (0) | 2021.09.15 |
[ boj : 2831 ] 댄스 파티 (0) | 2021.09.04 |
[ boj : 2157 ] 여행 (0) | 2021.08.29 |