結果
| 問題 | No.2195 AND Set |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-01-25 07:17:38 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
AC
|
| 実行時間 | 332 ms / 2,000 ms |
| コード長 | 858 bytes |
| 記録 | |
| コンパイル時間 | 242 ms |
| コンパイル使用メモリ | 86,004 KB |
| 実行使用メモリ | 110,388 KB |
| 最終ジャッジ日時 | 2026-03-13 05:39:52 |
| 合計ジャッジ時間 | 5,867 ms |
|
ジャッジサーバーID (参考情報) |
judge3_0 / judge1_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 13 |
ソースコード
import sys
input = sys.stdin.readline
from collections import *
flag = defaultdict(int)
cnt = 0
bit = [0]*30
for _ in range(int(input())):
qs = list(map(int, input().split()))
if qs[0]==1:
x = qs[1]
if flag[x]==0:
flag[x] = 1
cnt += 1
for b in range(30):
if (x>>b)&1:
bit[b] += 1
elif qs[0]==2:
x = qs[1]
if flag[x]==1:
flag[x] = 0
cnt -= 1
for b in range(30):
if (x>>b)&1:
bit[b] -= 1
else:
if cnt==0:
print(-1)
else:
ans = 0
for b in range(30):
if bit[b]==cnt:
ans += 1<<b
print(ans)