import sys
sys.setrecursionlimit(10**9)
input = sys.stdin.readline
n=int(input())
graph=[[] for _ in range(n+1)]
for _ in range(n-1):
p,c,cost=map(int,input().split())
graph[p].append([c,cost])
graph[c].append([p,cost])
result1=[0 for _ in range(n+1)]
def DFS(start,graph,result):
for e,d in graph[start]:
if result[e]==0:
result[e]=result[start]+d
DFS(e,graph,result)
DFS(1,graph,result1)
result1[1]=0
tmpmax=0
index=0
for i in range(len(result1)):
if tmpmax<result1[i]:
tmpmax=result1[i]
index=i
result2=[0 for _ in range(n+1)]
DFS(index,graph,result2)
result2[index]=0
print(max(result2))
# 가장 먼 노드를 찾고 그 노드들의 가중치를 찾아내주는 문제.
# 두 번의 DFS를 진행해주면 된다.
'문제풀이 > 백준(Boj) 문제풀이' 카테고리의 다른 글
[백준][Dijkstra/다익스트라] 1504번.특정한 최단 경로 (파이썬/Python) (0) | 2022.01.13 |
---|---|
[백준][자료구조/힙] 1715.카드 정렬하기 (파이썬/Python) (0) | 2022.01.11 |
[백준][자료구조/힙] 1655.가운데를 말해요 (파이썬/Python) (0) | 2022.01.10 |
[백준][자료구조/힙] 1655.가운데를 말해요 (파이썬/Python) (0) | 2022.01.08 |
[백준][자료구조/힙] 11279.최대 힙 (파이썬/Python) (0) | 2022.01.08 |