結果
問題 | No.763 Noelちゃんと木遊び |
ユーザー |
|
提出日時 | 2022-06-11 13:39:38 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 368 ms / 2,000 ms |
コード長 | 540 bytes |
コンパイル時間 | 407 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 179,456 KB |
最終ジャッジ日時 | 2025-03-22 10:41:20 |
合計ジャッジ時間 | 7,580 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 22 |
ソースコード
import sys input = lambda: sys.stdin.readline().rstrip() sys.setrecursionlimit(10**6) ################## n = int(input()) G = [[] for _ in range(n)] for _ in range(n-1): u, v = map(int, input().split()) u -= 1 v -= 1 G[u].append(v) G[v].append(u) dp = [[0, 0] for _ in range(n)] def dfs(p, v): ch0, ch1 = 0, 0 for x in G[v]: if x == p: continue dfs(v, x) ch0 += max(dp[x][0], dp[x][1]) ch1 += max(dp[x][0], dp[x][1]-1) dp[v][0] = ch0 dp[v][1] = ch1 + 1 dfs(-1, 0) # print(*dp) print(max(dp[0]))