結果

問題 No.763 Noelちゃんと木遊び
ユーザー standstillstandstill
提出日時 2021-05-14 23:40:43
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 383 ms / 2,000 ms
コード長 601 bytes
コンパイル時間 169 ms
コンパイル使用メモリ 82,176 KB
実行使用メモリ 185,728 KB
最終ジャッジ日時 2024-10-02 05:49:07
合計ジャッジ時間 7,337 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 381 ms
185,728 KB
testcase_01 AC 185 ms
85,632 KB
testcase_02 AC 332 ms
96,164 KB
testcase_03 AC 232 ms
89,344 KB
testcase_04 AC 198 ms
85,888 KB
testcase_05 AC 235 ms
89,344 KB
testcase_06 AC 357 ms
98,812 KB
testcase_07 AC 360 ms
98,432 KB
testcase_08 AC 252 ms
90,816 KB
testcase_09 AC 204 ms
86,016 KB
testcase_10 AC 135 ms
80,384 KB
testcase_11 AC 383 ms
99,072 KB
testcase_12 AC 342 ms
97,280 KB
testcase_13 AC 336 ms
97,232 KB
testcase_14 AC 299 ms
93,952 KB
testcase_15 AC 238 ms
89,484 KB
testcase_16 AC 122 ms
79,340 KB
testcase_17 AC 249 ms
89,728 KB
testcase_18 AC 360 ms
98,816 KB
testcase_19 AC 360 ms
97,024 KB
testcase_20 AC 343 ms
97,248 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

import sys
sys.setrecursionlimit(10**6)


def main():
  N = int(input())
  G = [[] for _ in range(N + 5)]
  for i in range(N - 1):
    u, v = map(int, input().split())
    G[u].append(v)
    G[v].append(u)

  dp = [[0] * 5 for _ in range(N + 5)]
  root = 1
  dfs(root, -1, G, dp)
  ans = max(dp[root][0], dp[root][1])
  print(f"{ans}")
  return


def dfs(u, parent, G, dp):
  dp[u][0], dp[u][1] = 1, 0
  for v in G[u]:
    if v == parent: continue
    dfs(v, u, G, dp)
    dp[u][0] += max(dp[v][0] - 1, dp[v][1])
    dp[u][1] += max(dp[v][0], dp[v][1])

  return


if __name__ == '__main__':
  main()
0