結果
問題 | No.2494 Sum within Components |
ユーザー |
|
提出日時 | 2023-10-06 21:32:16 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 451 ms / 2,000 ms |
コード長 | 699 bytes |
コンパイル時間 | 173 ms |
コンパイル使用メモリ | 82,688 KB |
実行使用メモリ | 109,700 KB |
最終ジャッジ日時 | 2024-07-26 15:48:28 |
合計ジャッジ時間 | 4,143 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 17 |
ソースコード
from collections import deque MOD = 998244353 N, M = map(int, input().split()) A = list(map(int, input().split())) edges = [[] for i in range(N)] for i in range(M): u, v = map(lambda x: x - 1, map(int, input().split())) edges[u].append(v) edges[v].append(u) ans = 1 done = [0] * N for i in range(N): if done[i]: continue done[i] = 1 dq = deque([i]) c = 1 s = A[i] while dq: now = dq.popleft() for nxt in edges[now]: if done[nxt]: continue done[nxt] = 1 dq.append(nxt) c += 1 s += A[nxt] s %= MOD ans *= pow(s, c, MOD) ans %= MOD print(ans)