#ABC249G. [ABC249G] Xor Cards

[ABC249G] Xor Cards

Score : 600600 points

Problem Statement

There are NN cards numbered 1,,N1, \dots, N. Card i(1iN)i \, (1 \leq i \leq N) has an integer AiA_i written on the front and an integer BiB_i written on the back.

Consider choosing one or more cards so that the exclusive logical sum of the integers written on the front of the chosen cards is at most KK. Find the maximum possible exclusive logical sum of the integers written on the back of the chosen cards.

What is the exclusive logical sum?

The exclusive logical sum aba \oplus b of two integers aa and bb is defined as follows.

  • The 2k2^k's place (k0k \geq 0) in the binary notation of aba \oplus b is 11 if exactly one of the 2k2^k's places in the binary notation of aa and bb is 11; otherwise, it is 00.

For example, 35=63 \oplus 5 = 6 (In binary notation: 011101=110011 \oplus 101 = 110). In general, the exclusive logical sum of kk integers p1,,pkp_1, \dots, p_k is defined as $(\cdots ((p_1 \oplus p_2) \oplus p_3) \oplus \cdots \oplus p_k)$. We can prove that it is independent of the order of p1,,pkp_1, \dots, p_k.

Constraints

  • 1N10001 \leq N \leq 1000
  • 0K<2300 \leq K \lt 2^{30}
  • 0Ai,Bi<230(1iN)0 \leq A_i, B_i \lt 2^{30} \, (1 \leq i \leq N)
  • All values in input are integers.

Input

Input is given from Standard Input in the following format:

NN KK

A1A_1 B1B_1

\vdots

ANA_N BNB_N

Output

Print the maximum possible exclusive logical sum of the integers written on the back of the chosen cards when choosing one or more cards so that the exclusive logical sum of the integers written on the front of the chosen cards is at most KK. If it is impossible to choose cards in such way, print 1-1 instead.

4 2
1 1
3 2
2 2
0 1
3

By choosing Cards 11 and 22, the exclusive logical sum of the integers written on the front of them is 22, and that on the back of them is 33, which is the maximum.

1 2
3 4
-1

It is impossible to choose cards so that the condition is satisfied.

10 326872757
487274679 568989827
267359104 968688210
669234369 189421955
1044049637 253386228
202278801 233212012
436646715 769734012
478066962 376960084
491389944 1033137442
214977048 1051768288
803550682 1053605300
1064164329