結果

問題 No.2195 AND Set
コンテスト
ユーザー Theta
提出日時 2023-01-27 15:11:22
言語 Python3
(3.14.3 + numpy 2.4.4 + scipy 1.17.1)
コンパイル:
python3 -mpy_compile _filename_
実行:
python3 _filename_
結果
AC  
実行時間 1,586 ms / 2,000 ms
コード長 1,259 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 818 ms
コンパイル使用メモリ 20,824 KB
実行使用メモリ 23,244 KB
最終ジャッジ日時 2026-03-16 10:08:14
合計ジャッジ時間 20,381 ms
ジャッジサーバーID
(参考情報)
judge3_1 / judge2_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 13
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

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