Acwing.143 最大异或对(trie树)

题目

在给定的N个整数A1,A2 . ...Ax中选出两个进行xor(异或)运算,得到的结果最大是多少?

输入格式

第一行输入一个整数N。

第二行输入N个整数A1~AN。

输出格式

输出一个整数表示答案。

数据范围

1 ≤N ≤105,0≤A<231

  • 输入样例:
java 复制代码
3
1 2 3
  • 输出样例
java 复制代码
3

题解

java 复制代码
import java.util.Scanner;

/**
 * @author akuya
 * @create 2023-07-24-0:00
 */
public class Mxor {
    static int N=100010;
    static int M=31*N;

    static int n;
    static int a[]=new int[N];
    static int son[][]=new int[M][2];
    static int idx;

    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        n=scanner.nextInt();
        int res=0;
        for(int i=0;i<n;i++){
            a[i]=scanner.nextInt();
        }


        for(int i=0;i<n;i++){
            insert(a[i]);
            int t=query(a[i]);
            res=Math.max(res,a[i]^t);
        }

        System.out.println(res);
    }

    public static void insert(int x){

        int p=0;
        for(int i=30;i>=0;i--){
            int u=x>>i&1;
            if(son[p][u]==0) son[p][u]=++idx;
            p=son[p][u];
        }

    }

    public static int query(int x){
        int p=0;
        int res=0;
        for(int i=30;i>=0;i--){
            int u=x>>i&1;
            if(son[p][u^1]!=0){
                p=son[p][1^u];
                res=res*2+1^u;
            }else{
                p=son[p][u];
                res=res*2+u;
            }
        }


        return res;
    }
}

思路

正常遍历时间复杂度为n2,利用trie树存起来,然后分解成二进制遍历。可以压缩时间复杂度到O(n)*O(31)。这样就不会超时了

相关推荐
naruto_lnq21 分钟前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq40 分钟前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
qq_2975746743 分钟前
【实战教程】SpringBoot 实现多文件批量下载并打包为 ZIP 压缩包
java·spring boot·后端
老毛肚44 分钟前
MyBatis插件原理及Spring集成
java·spring·mybatis
学嵌入式的小杨同学1 小时前
【Linux 封神之路】信号编程全解析:从信号基础到 MP3 播放器实战(含核心 API 与避坑指南)
java·linux·c语言·开发语言·vscode·vim·ux
lang201509281 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
Re.不晚1 小时前
Java入门17——异常
java·开发语言
爱吃rabbit的mq1 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
缘空如是1 小时前
基础工具包之JSON 工厂类
java·json·json切换
追逐梦想的张小年2 小时前
JUC编程04
java·idea