結果
| 問題 |
No.1689 Set Cards
|
| コンテスト | |
| ユーザー |
norioc
|
| 提出日時 | 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)
norioc