結果
問題 |
No.2047 Path Factory
|
ユーザー |
|
提出日時 | 2022-05-24 22:10:46 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 519 ms / 2,000 ms |
コード長 | 772 bytes |
コンパイル時間 | 1,041 ms |
コンパイル使用メモリ | 82,048 KB |
実行使用メモリ | 185,344 KB |
最終ジャッジ日時 | 2024-10-15 13:28:43 |
合計ジャッジ時間 | 8,165 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 27 |
ソースコード
import sys import pypyjit pypyjit.set_param(max_unroll_recursion = -1) sys.setrecursionlimit(200000) MOD = 998244353 N = int(input()) edge = [[] for _ in range(N)] for i in range(N-1): u, v = map(int, input().split()) u -= 1 v -= 1 edge[u].append(v) edge[v].append(u) def dfs(now, prv = -1): # must, can cannot subDp = (1, 0, 0) for nxt in edge[now]: if nxt == prv: continue child = dfs(nxt, now) connect = child[0] + child[1] disConnect = child[1] + child[2] subDp = ( subDp[0] * disConnect % MOD, (subDp[0] * connect + subDp[1] * disConnect) % MOD, (subDp[1] * connect + subDp[2] * disConnect) % MOD ) return subDp print(sum(dfs(0)[1:]) % MOD)