結果

問題 No.2195 AND Set
ユーザー ThetaTheta
提出日時 2023-01-27 15:12:05
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 667 ms / 2,000 ms
コード長 1,259 bytes
コンパイル時間 321 ms
コンパイル使用メモリ 87,128 KB
実行使用メモリ 88,468 KB
最終ジャッジ日時 2023-09-10 10:14:25
合計ジャッジ時間 9,548 ms
ジャッジサーバーID
(参考情報)
judge13 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 94 ms
71,636 KB
testcase_01 AC 93 ms
71,556 KB
testcase_02 AC 485 ms
80,588 KB
testcase_03 AC 471 ms
80,832 KB
testcase_04 AC 519 ms
80,740 KB
testcase_05 AC 570 ms
80,908 KB
testcase_06 AC 611 ms
81,788 KB
testcase_07 AC 561 ms
80,860 KB
testcase_08 AC 587 ms
80,292 KB
testcase_09 AC 517 ms
78,836 KB
testcase_10 AC 667 ms
87,756 KB
testcase_11 AC 633 ms
88,468 KB
testcase_12 AC 626 ms
88,048 KB
testcase_13 AC 632 ms
87,600 KB
testcase_14 AC 625 ms
88,092 KB
権限があれば一括ダウンロードができます

ソースコード

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