25902023-01-17 20:43:23kristofIntervallumXOR kihíváspython3Időlimit túllépés 35/100552ms28448 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 = 40000
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")
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva17ms11368 KiB
subtask215/15
2Elfogadva26ms11992 KiB
subtask30/15
3Időlimit túllépés504ms27992 KiB
subtask420/20
4Elfogadva17ms11996 KiB
subtask50/50
5Időlimit túllépés552ms28316 KiB
6Időlimit túllépés550ms28448 KiB