Acwing143最大异或对

题目

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

输入格式

第一行输入一个整数 N

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

输出格式

输出一个整数表示答案。

数据范围

1≤N≤10^5,

0≤Ai<2^31

输入样例:

复制代码
3
1 2 3

输出样例:

复制代码
3

代码

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

public class Main {
    static int idx, N = 3100010;
    static int[][] t = new int[N][2];  // 字典树数组,每个节点有两个子节点
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();  // 输入数组的长度
        int[] a = new int[n + 1];
        for (int i = 0; i < n; i++) {
            a[i] = in.nextInt();  // 读取数组元素
            insert(a[i]);  // 将数组元素插入字典树中
        }
        int res = 0;
        for (int i = 0; i < n; i++) {
            res = Math.max(res, query(a[i]));  // 查询数组元素的最大异或值
        }
        System.out.println(res);
    }

    // 查询给定数字 k 的最大异或值
    private static int query(int k) {
        int p = 0, res = 0;
        for (int i = 30; i >= 0; i--) {
            int u = k >> i & 1;  // 获取数字 k 的第 i 位二进制数
            if (t[p][1 - u] != 0) {  // 如果当前节点存在与 u 相反的子节点
                res += (1 << i);  // 更新结果
                p = t[p][1 - u];  // 移动到下一个节点
            } else {
                p = t[p][u];  // 否则移动到同一位的子节点
            }
        }
        return res;
    }

    // 将数字 k 插入字典树中
    private static void insert(int k) {
        int p = 0;
        for (int i = 30; i >= 0; i--) {
            int u = k >> i & 1;  // 获取数字 k 的第 i 位二进制数
            if (t[p][u] == 0) t[p][u] = ++idx;  // 如果当前节点不存在与 k 的第 i 位相同的子节点,则创建一个新的子节点
            p = t[p][u];  // 移动到下一个节点
        }
    }
}
相关推荐
xuzhiqiang072423 分钟前
【wiki知识库】07.用户管理后端SpringBoot部分
spring boot·后端·状态模式
谭光志35 分钟前
OpenClaw 安装与运行教程
前端·后端·ai编程
金牌归来发现妻女流落街头1 小时前
【Spring Boot 中 ResponseEntity 用法全解析】
spring boot·后端
+VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vue动漫交流与推荐平台系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
重生之后端学习2 小时前
98. 验证二叉搜索树
java·数据结构·后端·算法·职场和发展
qw102482 小时前
关于解决springcloud 创建bean失败的问题
后端·spring·spring cloud
用户298698530142 小时前
C# Word自动化:轻松插入特殊符号,告别手动烦恼!
后端·c#·.net
知其然亦知其所以然2 小时前
别再死记硬背!一篇讲透 Zookeeper 的 Watcher 机制
后端·zookeeper·面试
李慕婉学姐2 小时前
【开题答辩过程】以《智能小区物业管理系统设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·数据库·后端
m***06682 小时前
Spring Framework 中文官方文档
java·后端·spring