atcoder#ABC141F. [ABC141F] Xor Sum 3

[ABC141F] Xor Sum 3

配点: 600600

問題文

NN 個の非負整数 A1,A2,...,ANA_1, A_2, ..., A_N があります。

このうち 11 個以上 N1N-1 個以下を赤色で、残りを青色で塗り分けることを考えます。

塗り分けの 美しさ を、「赤く塗った整数の XOR\text{XOR}」と「青く塗った整数の XOR\text{XOR}」の和とします。

塗り分けの美しさの最大値を求めてください。

$\text{XOR}$ とは

nn 個の非負整数 x1,x2,,xnx_1,x_2, \ldots, x_nXOR\text{XOR} x1x2xnx_1 \oplus x_2 \oplus \ldots \oplus x_n は以下のように定義されます。

  • x1x2xnx_1 \oplus x_2 \oplus \ldots \oplus x_n を二進表記した際の 2k(k0)2^k(k \geq 0) の位の数は x1,x2,,xnx_1,x_2, \ldots, x_n のうち、二進表記した際の 2k(k0)2^k(k \geq 0) の位の数が 11 となるものの個数が奇数ならば 11、そうでなければ 00 となる。

例えば、35=63 \oplus 5 = 6 となります。

制約

  • 入力はすべて整数
  • 2N1052 \leq N \leq 10^5
  • 0Ai<260 (1iN)0 \leq A_i < 2^{60}\ (1 \leq i \leq N)

入力

入力は以下の形式で標準入力から与えられます。

NN

A1A_1 A2A_2 ...... ANA_N

出力

塗り分けの美しさの最大値を出力してください。

3
3 6 5
12

(3,6,5)(3, 6, 5) をそれぞれ (,,)(青, 赤, 青) で塗り分けたとき、美しさは (6)+(35)=12(6) + (3 \oplus 5) = 12 になります。

1212 よりも高い美しさの塗り分けは存在しないので、答えは 1212 です。

4
23 36 66 65
188
20
1008288677408720767 539403903321871999 1044301017184589821 215886900497862655 504277496111605629 972104334925272829 792625803473366909 972333547668684797 467386965442856573 755861732751878143 1151846447448561405 467257771752201853 683930041385277311 432010719984459389 319104378117934975 611451291444233983 647509226592964607 251832107792119421 827811265410084479 864032478037725181
2012721721873704572

AiA_i や答えは 3232 ビット整数型に収まらないことがあります。