結果
問題 | No.2195 AND Set |
ユーザー |
|
提出日時 | 2022-11-28 23:01:29 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 625 ms / 2,000 ms |
コード長 | 879 bytes |
コンパイル時間 | 212 ms |
コンパイル使用メモリ | 82,264 KB |
実行使用メモリ | 132,480 KB |
最終ジャッジ日時 | 2024-10-06 00:39:03 |
合計ジャッジ時間 | 9,726 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 13 |
ソースコード
def solve(q, qu): s = set() X = [] bit = [0] * 30 for v in qu: t = v[0] if t == 1: x = v[1] if x not in s: s.add(x) for i in range(30): if 1 & (x >> i): bit[i] += 1 elif t == 2: x = v[1] if x in s: s.discard(x) for i in range(30): if 1 & (x >> i): bit[i] -= 1 else: ans = 0 if len(s) == 0: X.append(-1) else: for i in range(30): if bit[i] == len(s): ans += 2 ** i X.append(ans) return X q = int(input()) qu = [list(map(int,input().split())) for _ in range(q)] for v in solve(q, qu): print(v)