結果
| 問題 | No.3412 Christmas Tree Coloring |
| コンテスト | |
| ユーザー |
koheijkt
|
| 提出日時 | 2026-01-16 18:39:18 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,323 bytes |
| 記録 | |
| コンパイル時間 | 518 ms |
| コンパイル使用メモリ | 82,332 KB |
| 実行使用メモリ | 178,960 KB |
| 最終ジャッジ日時 | 2026-01-16 18:39:38 |
| 合計ジャッジ時間 | 19,656 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 15 WA * 5 |
ソースコード
import sys
sys.setrecursionlimit(10**8)
import pypyjit
pypyjit.set_param('max_unroll_recursion=-1')
MOD = 998244353
N = int(input())
G = [list() for _ in range(N)]
for i in range(N - 1):
u, v = map(int, input().split())
u -= 1
v -= 1
G[u].append(v)
G[v].append(u)
# 木DP
DP = [[[0] * (2) for _ in range(3)] for _ in range(N)]
def dfs(pos, pre):
soseki = [1, 1]
memo2 = 1
for nex in G[pos]:
if nex == pre:
continue
dfs(nex, pos)
for j in range(2):
soseki[j] *= DP[nex][0][0]
soseki[j] %= MOD
# 茶色
memo2 *= DP[nex][0][0] + DP[nex][1][0]
memo2 %= MOD
# 茶
DP[pos][2][0] = memo2
# 総積は求められている
DP[pos][0][0] = soseki[1] # 赤未
DP[pos][1][0] = soseki[0] # 緑未
memo01 = 0 # 赤既
memo11 = 0 # 緑既
for nex in G[pos]:
if nex == pre:
continue
memo01 += soseki[1] * pow(DP[nex][1][0], -1, MOD) * (DP[nex][2][0] + DP[nex][1][1])
memo01 %= MOD
memo11 += soseki[0] * pow(DP[nex][0][0], -1, MOD) * (DP[nex][2][0] + DP[nex][0][1])
memo11 %= MOD
# 赤既、緑既
DP[pos][0][1] = memo01
DP[pos][1][1] = memo11
dfs(0, -1)
ans = DP[0][0][1] + DP[0][1][1] + DP[0][2][0]
ans %= MOD
print(ans)
koheijkt