Acwing---143. 最大异或对

最大异或对

1.题目

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

输入格式

第一行输入一个整数 N。

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

输出格式

输出一个整数表示答案。

数据范围
1 ≤ N ≤ 1 0 5 , 1≤N≤10^5, 1≤N≤105,

0 0 0≤ A i Ai Ai<2^31

输入样例:

3

1 2 3

输出样例:

3

2.基本思想

  • 1.son数组定义是二维数组,son[n][m],可以先理解它的第二维度,只有两种状态0/1,是因为这一位表示的是某个数字的的某一位是0 / 1,而第一维的大小是我们用的十位二进制表示下一共有多少位数,在本题中,数字一共有N个数字,N是小于10^5的,一个数在int下是32位,则我们需要至多3200000的一维坐标,而p = son[n][0] / p = son[n][1]其实存的值就是他的两个子节点的一维坐标的值。

    那么x >> i & 1 其实就是我想知道x的二进制表示中的第i位(二进制位从第0位开始表示第0位 - 第 31 位),本题的题目范围到2^31那么就是i从30 - 0

  • 2.构建逻辑其实相对简单,就是将数的二进制表示插入到son数组中,如果没有那么就将他的值附上++idx即可

  • 3.查询的时候为了异或大小最大,那么就应该从根节点开始遍历最高位开始尽量让异或结果为1,在遍历查询数字的第i位的时候取第i位的值为s,查看son[p][!s]是否存在,如果存在那么将res+= i << i(这一位异或存在最大值为1),如果没有那么就让p = son[p][s]

3.代码实现

csharp 复制代码
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Scanner;

public class Main {
    static int N = 3000010;
    static int[][] son = new int[N][2];
    static int idx;
    static int[] a = new int[N];

    public static void main(String[] args) throws IOException {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        for (int i = 0; i < n; i++) {
            a[i] = sc.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);
    }

    private static void insert(int x) {
        int p = 0;
        for (int i = 30; i >= 0; i--) {//从30开始枚举
            int s = son[p][(x >> i) & 1];//看 x的二进制表示中 个位 是 0 还是 1
            if (s == 0) son[p][(x >> i) & 1] = ++idx;//创建新节点
            p = son[p][(x >> i)&1];
        }
    }

    private static int query(int x) {
        int res = 0, p = 0;
        for (int i = 30; i >= 0; i--) {//从30开始枚举
            int s = (x >> i) & 1;//看 x的二进制表示中 个位 是 0 还是 1
            if (son[p][1 - s] != 0) {
                res += (1 << i);
                p = son[p][1 - s];
            } else p = son[p][s];
        }
        return res;
    }
}
相关推荐
wabs6661 天前
关于贪心算法的思考
算法·贪心算法
社交怪人1 天前
【判断大小】信息学奥赛一本通C语言解法(题号1043)
算法
许彰午1 天前
14_Java泛型完全指南
java·windows·python
Snasph1 天前
GNU Make 用户手册(中文版)
服务器·算法·gnu
智慧物业老杨1 天前
司法绿色通道下的物业纠纷数智化解决方案——基于“三优先“机制的全流程技术落地实践
java·django
2601_961194021 天前
2026初级会计实务公式总结大全|计算题公式手册PDF
java·spring·eclipse·pdf·tomcat·hibernate
做个文艺程序员1 天前
第1篇:K8s 核心概念精讲:Pod、Deployment、Service 与 Namespace——Java 开发者快速上手指南
java·云原生·容器·kubernetes·容器编排
江澎涌1 天前
拆解与 AI 的一次对话
人工智能·算法·程序员
sheeta19981 天前
LeetCode 每日一题笔记 日期:2026.06.02 题目:3635. 最早完成陆地和水上游乐设施的时间 II
笔记·算法·leetcode
Lsk_Smion1 天前
力扣实训 _ [102].层序遍历--前序--后续_递归与非递归的实现
数据结构·算法·leetcode