結果
問題 | No.1689 Set Cards |
ユーザー |
![]() |
提出日時 | 2025-03-27 03:20:02 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 89 ms / 2,000 ms |
コード長 | 521 bytes |
コンパイル時間 | 605 ms |
コンパイル使用メモリ | 82,388 KB |
実行使用メモリ | 74,224 KB |
最終ジャッジ日時 | 2025-03-27 03:20:06 |
合計ジャッジ時間 | 3,429 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 23 |
ソースコード
MOD = 998244353 N = int(input()) sets = [] for _ in range(N): _, *C = map(int, input().split()) b = 0 for c in C: b |= (1 << (c-1)) sets.append(b) sz = 12 bit_all = (1 << sz) - 1 bps = [0] * (1 << sz) for i in range(1, 1 << sz): for b in sets: if (i & b) == i: bps[i] += 1 cnt = 0 for i in range(1 << sz): sgn = 1 if i.bit_count() % 2 == 1 else -1 x = pow(2, bps[i]) - 1 cnt += sgn * x cnt %= MOD ans = (pow(2, N, MOD) - 1) - cnt ans %= MOD print(ans)