結果
問題 | 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 sysimport pypyjitpypyjit.set_param(max_unroll_recursion = -1)sys.setrecursionlimit(200000)MOD = 998244353N = int(input())edge = [[] for _ in range(N)]for i in range(N-1):u, v = map(int, input().split())u -= 1v -= 1edge[u].append(v)edge[v].append(u)def dfs(now, prv = -1):# must, can cannotsubDp = (1, 0, 0)for nxt in edge[now]:if nxt == prv: continuechild = 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 subDpprint(sum(dfs(0)[1:]) % MOD)