結果
| 問題 |
No.2195 AND Set
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-01-25 07:17:38 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 463 ms / 2,000 ms |
| コード長 | 858 bytes |
| コンパイル時間 | 1,052 ms |
| コンパイル使用メモリ | 82,176 KB |
| 実行使用メモリ | 105,236 KB |
| 最終ジャッジ日時 | 2024-06-26 12:40:32 |
| 合計ジャッジ時間 | 8,257 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| 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)