25932023-01-17 20:52:32kristofIntervallumXOR kihíváspython3Időlimit túllépés 35/100601ms28680 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
all = ""
for i in range(N):
    xx = x[i]
    aa = xx % 4
    if aa == 0:
        xor = xx
    if aa == 1:
        xor = 1
    if aa == 2:
        xor = xx + 1
    if aa == 3:
        xor = 0
    drop = xor
    m = mm
    for index in range(30):
        if m ^ drop <= xx:
            drop ^= m
        m >>= 1
    #print(xor, xor ^ drop)
    all = all + str(xor) + " " + str(xor ^ drop) + "\n"
    # sys.stdout.write(str(xor) + " " + str(xor ^ drop) + "\n")
sys.stdout.write(all)

RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva17ms11620 KiB
subtask215/15
2Elfogadva26ms11472 KiB
subtask30/15
3Időlimit túllépés551ms28680 KiB
subtask420/20
4Elfogadva17ms12144 KiB
subtask50/50
5Időlimit túllépés601ms13224 KiB
6Időlimit túllépés569ms13328 KiB