1167번 : 트리의 지름 - Python

Pobi·2023년 4월 15일
0

PS

목록 보기
71/107

문제

https://www.acmicpc.net/problem/1167

풀이

DFS를 이용해서 1에서 가장 먼 노드(v)를 찾고, 다시 v에서 가장 먼 노드를 찾는다. v에서 그 노드까지의 거리가 트리의 지름이 된다.

코드

import sys 

sys.setrecursionlimit(10**6)
input = sys.stdin.readline

def dfs(n, m):
    visit[n] = m #visit에 n까지의 거리를 저장한다.
    
    for i in array[n]:
        if visit[i[0]]==-1: #i[0]를 방문하지 않았다면 방문
            dfs(i[0],m+i[1]) #i[0]을 방문하면서 거리를 n에서 i[0]까지의 거리를 더한다.


n = int(input())
array = [[] for _ in range(n+1)]
visit = [-1] * (n+1)

for i in range(n):
    li = list(map(int,input().split()))

    for j in range(1,len(li)-1,2):
        array[li[0]].append((li[j],li[j+1]))
    
dfs(1,0)


v = visit.index(max(visit)) #node(1)에서 가장 먼 노드 v

visit = [-1] * (n+1)
dfs(v,0) #node(v)에서 가장 먼 node까지의 길이를 다시 구한다.

print(max(visit))

비슷한 문제

1967번 : 트리의 지름 / 풀이

profile
꿈 많은 개발자

0개의 댓글