Description
给定一个数列,从中选出两个数,求异或的最大值。
Solution
01trie模板题。
我们将数据以二进制形式储存在trie树中,每次查询时,从大位到小位尽可能选与当前相异的数据。
code
#include<bits/stdc++.h>
using namespace std;
int n,a[1050000];
int trie[10500000][2],tot=0,ans=-1;
void insert(int x){
int p=0;
for(int i=31;i>=0;--i){
int c=(x>>i)&1;
if(trie[p][c]==0)trie[p][c]=++tot;
p=trie[p][c];
}
}
int query(int x){
int p=0,sum=0;
for(int i=31;i>=0;--i){
int c=(x>>i)&1;
if(trie[p][!c]){
p=trie[p][!c];
sum=(sum<<1)|1;
}
else{
p=trie[p][c];
sum=sum<<1;
}
}
return sum;
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;++i){
scanf("%d",&a[i]);
insert(a[i]);
}
for(int i=1;i<=n;++i)ans=max(ans,query(a[i]));
printf("%d\n",ans);
return 0;
}