码迷,mamicode.com
首页 > Windows程序 > 详细

AcWing 143. 最大异或对

时间:2020-07-30 14:44:26      阅读:184      评论:0      收藏:0      [点我收藏+]

标签:c++   进制   枚举   最大   for   ace   异或   ++   print   

AcWing 143. 最大异或对


/*暴力做法
int res=0;
for(int i=0;i<n;i++)    //枚举第一个数
    for(int j=0;j<i;j++)    //枚举第二个数
        res=max(res,a[i]^a[j);
*/
#include <bits/stdc++.h>
using namespace std;
const int N=1e6+10,M=31*N;
int n;
int a[N];
int son[M][2],idx;
void insert(int x){
    int p=0;
    for(int i=30;i>=0;i--){
        int u=x >> i &1;//取出x二进制的第i位数
        if(!son[p][u]) son[p][u]=++idx;
        p=son[p][u];
    }
}
int query(int x){
    int p=0,res=0;
    for(int i=30;i>=0;i--){
        int u=x >> i &1;//取出x二进制的第i位数
        if(son[p][!u]){
            p=son[p][!u];
            res=res*2+!u;
        }
        else{
            p=son[p][u];
            res=res*2+u;
        } 
    }
    return res;
}
int main(){
    scanf("%d",&n);
    for(int i=0;i<n;i++) scanf("%d",&a[i]);
    int res=0;
    for(int i=0;i<n;i++){
        insert(a[i]);
        int t=query(a[i]);
        res=max(res,a[i]^t);
    }
    printf("%d",res);
    return 0;
}

AcWing 143. 最大异或对

标签:c++   进制   枚举   最大   for   ace   异或   ++   print   

原文地址:https://www.cnblogs.com/wiseXu/p/13403048.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!