25882023-01-17 20:41:28kristofIntervallumXOR kihíváspython3Wrong answer 35/100319ms28356 KiB
from sys import stdin, stdout
import sys
import os
pow2 = [1 << i for i in range(30)][::-1]
mm = pow2[0]
N = int(input())
x = [int(stdin.readline()) for i in range(N)]
max = 20000
if N > max: N = max
for i in range(N):
    xx = x[i]
    if xx % 4 == 0:
        xor = xx
    if xx % 4 == 1:
        xor = 1
    if xx % 4 == 2:
        xor = xx + 1
    if xx % 4 == 3:
        xor = 0
    drop = xor
    m = mm
    for index in range(30):
        if m ^ drop <= xx:
            drop ^= m
        m >>= 1
    #print(xor, xor ^ drop)
    sys.stdout.write(str(xor) + " " + str(xor ^ drop) + "\n")
SubtaskSumTestVerdictTimeMemory
subtask10/0
1Accepted18ms11108 KiB
subtask215/15
2Accepted27ms12132 KiB
subtask30/15
3Wrong answer293ms28104 KiB
subtask420/20
4Accepted17ms11944 KiB
subtask50/50
5Wrong answer316ms28356 KiB
6Wrong answer319ms28232 KiB