結果
問題 |
No.1928 Make a Binary Tree
|
ユーザー |
![]() |
提出日時 | 2022-05-07 23:58:51 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
TLE
|
実行時間 | - |
コード長 | 793 bytes |
コンパイル時間 | 305 ms |
コンパイル使用メモリ | 12,928 KB |
実行使用メモリ | 89,888 KB |
最終ジャッジ日時 | 2024-07-07 06:03:56 |
合計ジャッジ時間 | 17,965 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 33 TLE * 1 -- * 23 |
ソースコード
from sys import setrecursionlimit setrecursionlimit(10**6) from heapq import heappop,heappush def dfs(pos, pre): global Vec for nxt in G[pos]: if nxt == pre: continue P = dfs(nxt, pos) heappush(Vec[pos], -P) for nxt in G[pos]: if nxt == pre: continue while Vec[nxt]: heappush(Vec[pos], heappop(Vec[nxt])) ret = 1 if len(Vec[pos]) <= 2: while Vec[pos]: ret += -heappop(Vec[pos]) else: for _ in range(2): ret += -heappop(Vec[pos]) return ret N = int(input()) G = [[] for _ in range(N)] for _ in range(N-1): x,y = map(int,input().split()) x -= 1 y -= 1 G[x].append(y) G[y].append(x) Vec = [[] for _ in range(N)] print(dfs(0, -1))