#include using namespace std; #define i64 long long #define rep(i,s,e) for(int (i) = (s);(i) <= (e);(i)++) int N; vector A; i64 ans = 0; int rec2(int,i64,i64); int rec(int bit,i64 XOR){ if(bit == (1 << N) - 1){ ans = max(ans , XOR); return 0; } for(int i = 0;i < N;i++){ if ((bit & (1 << i))) continue; rec2(bit | (1 << i),XOR,A[i]); } return 0; } int rec2(int bit,i64 XOR,i64 temp){ if(bit == (1 << N) - 1){ ans = max(ans , XOR); return 0; } for(int i = 0;i < N;i++){ if ((bit & (1 << i))) continue; rec(bit | (1 << i), XOR ^ (A[i] + temp)); } return 0; } int main(){ cin >> N; A.resize(N); rep(i,0,N - 1) cin >> A[i]; rec(0,0); cout << ans << endl; }