結果
| 問題 |
No.1878 union-find の数え上げ
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-03-18 22:31:32 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 149 ms / 2,000 ms |
| コード長 | 355 bytes |
| コンパイル時間 | 189 ms |
| コンパイル使用メモリ | 82,504 KB |
| 実行使用メモリ | 91,024 KB |
| 最終ジャッジ日時 | 2024-10-03 09:42:40 |
| 合計ジャッジ時間 | 2,150 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 13 |
ソースコード
MOD = 998244353
n = int(input())
edges = [[] for _ in range(n)]
for i in range(1, n):
p = int(input()) - 1
edges[p].append(i)
dist = [0] * n
stack = [0]
ans = 1
while stack:
pos = stack.pop()
for npos in edges[pos]:
dist[npos] = dist[pos] + 1
ans *= dist[npos]
ans %= MOD
stack.append(npos)
print(ans)