結果
問題 |
No.3113 The farthest point
|
ユーザー |
![]() |
提出日時 | 2025-04-19 15:06:51 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,460 ms / 2,000 ms |
コード長 | 719 bytes |
コンパイル時間 | 503 ms |
コンパイル使用メモリ | 82,132 KB |
実行使用メモリ | 178,068 KB |
最終ジャッジ日時 | 2025-04-19 15:07:17 |
合計ジャッジ時間 | 25,290 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 33 |
ソースコード
n=int(input()) e=[[] for _ in range(n)] for _ in range(n-1): u,v,w=map(int,input().split()) u-=1 v-=1 e[u]+=[(v,w)] e[v]+=[(u,w)] X=10**20 u=[[0,-X] for _ in range(n)] v=[0]*n q=[0] while len(q): s=q[-1] if v[s]==0: v[s]=1 for t,c in e[s]: if v[t]==0: q+=[t] else: for t,c in e[s]: if v[t]==0: u[s]+=[u[t][0]+c] u[s]=(sorted(u[s])[-2:])[::-1] v[s]=0 q.pop() v=[0]*n q=[0] while len(q): s=q[-1] if v[s]==0: v[s]=1 for t,c in e[s]: if v[t]==0: q+=[t] u[t]+=[u[s][u[s][0]==u[t][0]+c]+c] u[t]=(sorted(u[t])[-2:])[::-1] else: v[s]=0 q.pop() print(max(u[s][0]+u[s][1]*(len(e[s])>1) for s in range(n)))