結果

問題 No.2195 AND Set
ユーザー ThetaTheta
提出日時 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
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 44 ms
54,184 KB
testcase_01 AC 45 ms
55,092 KB
testcase_02 AC 442 ms
79,076 KB
testcase_03 AC 435 ms
79,476 KB
testcase_04 AC 441 ms
79,080 KB
testcase_05 AC 513 ms
79,208 KB
testcase_06 AC 563 ms
79,856 KB
testcase_07 AC 502 ms
77,984 KB
testcase_08 AC 518 ms
79,008 KB
testcase_09 AC 476 ms
77,396 KB
testcase_10 AC 640 ms
85,296 KB
testcase_11 AC 603 ms
84,532 KB
testcase_12 AC 584 ms
84,148 KB
testcase_13 AC 588 ms
84,276 KB
testcase_14 AC 593 ms
84,896 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