結果

問題 No.2195 AND Set
ユーザー Theta
提出日時 2023-01-27 15:12:05
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 640 ms / 2,000 ms
コード長 1,259 bytes
コンパイル時間 223 ms
コンパイル使用メモリ 82,164 KB
実行使用メモリ 85,296 KB
最終ジャッジ日時 2024-06-28 01:39:50
合計ジャッジ時間 8,415 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 13
権限があれば一括ダウンロードができます

ソースコード

diff #

from collections import defaultdict


def main():
    S = set()
    S_bit_digit = [0 for _ in range(30)]

    for _ in range(int(input())):
        query = input().split()
        if len(query) == 1:
            query_type = 3
        else:
            query_type, x = map(int, query)

        if query_type == 1:
            if x in S:
                continue
            S.add(x)

            digit_idx = 0
            while x > 0:
                if x & 1:
                    S_bit_digit[digit_idx] += 1
                x >>= 1
                digit_idx += 1

        elif query_type == 2:
            if x not in S:
                continue
            S.remove(x)

            digit_idx = 0
            while x > 0:
                if x & 1:
                    S_bit_digit[digit_idx] -= 1
                x >>= 1
                digit_idx += 1
        elif query_type == 3:
            if not S:
                print(-1)
            else:
                bitwise_ = 0
                for digit_idx, digit_value in enumerate(S_bit_digit):
                    if digit_value == len(S):
                        bitwise_ += 2 ** digit_idx
                print(bitwise_)
        else:
            raise ValueError


if __name__ == "__main__":
    main()
0