/********include********/ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define popcount __builtin_popcount using namespace std; /***/ //#include //#include #include /********define********/ #define rep(i,x) for(long long i=0;i=0;i--) #define rrepn(i,x) for(long long i=x;i>1;i--) #define REP(i,n,x) for(long long i=n;i(b))?(a):(b)) #define MIN(a,b) (((a)<(b))?(a):(b)) typedef long long int ll; typedef pair P; /********128bit CFではコンパイルNG********/ /* std::ostream &operator<<(std::ostream &dest, __int128_t value) { std::ostream::sentry s(dest); if (s) { __uint128_t tmp = value < 0 ? -value : value; char buffer[128]; char *d = std::end(buffer); do { --d; *d = "0123456789"[tmp % 10]; tmp /= 10; } while (tmp != 0); if (value < 0) { --d; *d = '-'; } int len = std::end(buffer) - d; if (dest.rdbuf()->sputn(d, len) != len) { dest.setstate(std::ios_base::badbit); } } return dest; } __int128 parse(string &s) { __int128 ret = 0; for (int i = 0; i < s.length(); i++) if ('0' <= s[i] && s[i] <= '9') ret = 10 * ret + s[i] - '0'; return ret; } */ /********よく使う関数********/ // 素因数分解 vector > prime_factorize(long long n) { vector > res; for (long long p = 2; p * p <= n; ++p) { if (n % p != 0) continue; int num = 0; while (n % p == 0) { ++num; n /= p; } res.push_back(make_pair(p, num)); } if (n != 1) res.push_back(make_pair(n, 1)); return res; } // 約数列挙 vector calc_divisor(long long n) { vector res; for (long long i = 1LL; i*i <= n; ++i) { if (n % i == 0) { res.push_back(i); long long j = n / i; if (j != i) res.push_back(j); } } sort(res.begin(), res.end()); return res; } //最大公約数 ll gcd(ll x, ll y) { return y ? gcd(y, x % y) : x; } //最大公約数 複数個 ll gcd(const vector &v) { ll ret = v[0]; for (ll i = 1; i < v.size(); i++) ret = gcd(ret, v[i]); return ret; } //最小公倍数 ll lcm(ll x, ll y) { return x / gcd(x, y) * y; } //最小公倍数 複数個 ll lcm(const vector &v) { ll ret = v[0]; for (ll i = 1; i < v.size(); i++) ret = lcm(ret, v[i]); return ret; } /********変数宣言********/ //vector g[200020]; vector> g[200020]; ll s[200020]; bool used[200020]; //bool dp[100005]; ll A,B,C,D,H,K,M,N,Q,R,S,T,W,X,Y; double dA,dB,dC,dH,dK,dM,dN,dQ,dR,dS,dT,dW,dX,dY; //1000000000000000000 //10^18 //1000000000 //10^9 int main() { cin.tie(0); ios::sync_with_stdio(false); /********よく使う********/ //std::sort(v.begin(),v.end());//昇順ソート //std::sort(v.begin(),v.end(),std::greater());//降順ソート //v.erase(unique(v.begin(), v.end()), v.end()); //vector v(N, 0); //vector > p(N); //sort(p.begin(), p.end()); //sort(p.begin(), p.end(),greater >()); //priority_queue, greater > que; //priority_queue que; //map> mp; //deque dque; //string s; //wk=(ll)stoi(s); //set st; //stack sta; //queue que; //s.insert(0, " "); //reverse(s.begin(),s.end()); //do{ //}while(next_permutation(v.begin(),v.end())); //__int128 aa = 1; /******初期化***********/ long long ans,sum,cnt,cnt1,flg,flg1,flg2; long long max,max1; long long min,min1; long long wk,wk1; max=max1=wk=wk1=sum=ans=cnt=cnt1=flg=flg1=flg2=0; min=min1=INF; double dwk,dwk1,dsum,dsum1,dans,dans1; dwk=dwk1=dsum=dsum1=dans=dans1=0; cin >> N; vectorv(N); deque dque; rep(i,N){ cin >> wk; dque.push_back(wk); } sort(dque.begin(),dque.end()); vectorw; rep(i,N){ rep(j,N){ if(i==j)continue; max=MAX(dque[i]^dque[j],max); } } pr("%lld",max); re 0; /* while(!dque.empty()){ if(cnt%2==0){ w.push_back(dque.back()); dque.pop_back(); //v.pop_back(); } else{ w.push_back(dque.front()); dque.pop_front(); //v.pop_front(); } cnt++; } */ vectorx; /* rep(i,N-1){ x.push_back(w[i]^w[i+1]); } */ /* ans=x[0]; for(ll i=1;i> T; while(T--){ cin >> N >> K; std::vector v(N); // 配列入力1 /* for(long long i=0; i> v[i]; } */ //cout << sum << '\n'; //文字列の出力 //std::cout << s << std::endl; //} //re 0; /******よく使う***********/ //素因数分解 /* auto pf = prime_factorize(v[i]); for(auto p:pf){ if(p.se!=wk){ } } */ //約数列挙 /* vector div = calc_divisor(M); // M の約数 d であって、d * N <= M となる最大の d を求める long long res = 1; for (auto d : div) { if (d * N <= M) res = max(res, d); } */ //最小公倍数 /* std::vector v(N); rep(i, N) { cin >> v[i]; } cout << lcm(v) << endl; return 0; */ //最小公約数 /* std::vector v(N); rep(i, N) { cin >> v[i]; } cout << gcd(v) << endl; return 0; */ //素数判定 /* for(int i=x; ; i++){ bool dame=0; for(int j=2; j*j<=i; j++){ if(i%j==0){ dame=1; break; } } if(!dame){ cout< st; for(long long i=0; i> v[i]; if(st.find(v[i])==st.end()){ st.insert(v[i]); } else{ st.erase(v[i]); } } //if(ceil(sqrt(wk)==floor(sqrt(wk)))) //do{ //}while(next_permutation(v.begin(),v.end())); /******出力関連***********/ //pr("%lld\n",N); //printf("%lld",(ll)ceil(dB/dA)); //puts("Yes"); //文字列の出力 //std::cout << s << std::endl; //printf("%.12f\n",ret); //cout << sum << '\n'; //pr("%02lld:%02lld",wk/60,wk%60); re 0; }