当前位置: 首页 > news >正文

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

题目

在给定的N个整数A1,A2 . …Ax中选出两个进行xor(异或)运算,得到的结果最大是多少?
输入格式
第一行输入一个整数N。
第二行输入N个整数A1~AN。

输出格式

输出一个整数表示答案。

数据范围

1 ≤N ≤105,0≤A<231

  • 输入样例:
3
1 2 3
  • 输出样例
3

题解

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)。这样就不会超时了

http://www.lryc.cn/news/185379.html

相关文章:

  • day10.8ubentu流水灯
  • transformer系列5---transformer显存占用分析
  • Docker项目部署
  • vue3实现文本超出鼠标移入的时候文本滚动
  • 光伏系统MPPT、恒功率控制切换Simulink仿真
  • mysql双主互从通过KeepAlived虚拟IP实现高可用
  • ​苹果应用高版本出现:“无法安装此app,因为无法验证其完整性”是怎么回事?竟然是错误的?
  • AF_UNIX和127.0.0.1(AF_INET)回环地址写数据速度对比
  • 我在 NPM 发布了新包: con-colors
  • 【python数据建模】Scipy库
  • C# App.xaml.cs的一些操作
  • 【ORACLE】ORA-00972:标识符过长
  • 【Vue】Vue快速入门、Vue常用指令、Vue的生命周期
  • Pandas 数据处理 类别数据和数值数据
  • Android攻城狮学鸿蒙 -- 点击事件
  • jmeter性能测试常见的一些问题
  • 利用国外 vps 为 switch 设置代理服务器加速游戏下载
  • 云计算安全的新挑战:零信任架构的应用
  • 基于SSM的药房药品采购集中管理系统的设计与实现
  • 【GIT版本控制】--远程仓库
  • 1:Allotment,2:FeeSell,3:混合Allotment+FreeSell
  • NFT Insider#110:The Sandbox与TB Media Global合作,YGG Web3游戏峰会阵容揭晓
  • 在硅云上主机搭建wordpress并使用Astra主题和avada主题
  • 基于SSM+Vue的物流管理系统的设计与实现
  • 【洛谷】P1114 “非常男女”计划
  • list中符合 多条件中筛选符合条件的值
  • Amber中的信息传递——章节1.2-第三部分
  • 【嵌入式】常用串口协议与转换芯片详解
  • 缓存与数据库双写一致性问题解决方案
  • Java中的transient关键字是什么意思?