3.7 最大异或对
创始人
2024-05-29 23:51:46
0

异或

二进制位同为0,异为1
异或符号 ^
异或性质
a^a=0 a^0=0
(a^ b ^c) =(a^c ^b)

一道异或的题目

最大异或对

题目链接

思路

注重思维方式

  1. 首先是暴力想法,使用两重循环,对每两个数字进行取异或运算,得出最大值
  2. 考虑如何优化
  3. 首先,两重for循环的第一层无法优化,因为确实需要至少枚举一次数字。那么考虑优化第二层
  4. 那么这么想,如果给定了一个固定的数字a,我们如何找到另外一个数字b使得 a^b最大。因为异或运算,从二进制角度思考如果我们想让一个数最大,那么这个数的高位应该是1
    在这里插入图片描述
    如上图,对于a=10110,我们要找的b就最好每一位都是a的每一位取!,这样异或出来就是11111,这样就是最大的
  5. 那么第二重循环的目的就是,如何快速找到这样的b。因此我们考虑使用Trie树存储某个数的二进制表示:

    如果我们像这样存储数字,那么在查找时就可以从树根往下找我们想要的!的数字。另一支就根本不用考虑注意,树从上往下应该是从高位到地位,符合贪心的思维,因此可以得到最大值。
  6. 由此可见,思路就很明显了:用Trie树存储所有的数字(二进制从高位到低位存储),然后两层循环,第一层用于遍历所有数值,固定住此时的a。第二层用于搜寻对于a,Trie树中哪一个b使得a^b更大。最后比较每一个a所对应的a ^ b即可。

关于二进制数位的运算在代码中详细解释。详见代码注释。

实现代码


#include
#includeusing namespace std;//N用于标注数字的数量,M用于标注节点的数量。
//由于每个数字的范围是0-2^31,因此位数最多31位,最多1e5个数字,节点总数最多为31*1e5约为3*1e6 
const int N=1e5+10,M=3*1e6+1e5;//定义Trie树,不需要用记录num的数组,因为如果不存在,后面都是0,对于异或运算没影响 
int son[M][2],idx=0;
int a[N];//用于存放数字的数组 void insert(int x){//将x插入Trie树int p=0;for(int i=30;i>=0;i--){//这里是30是因为数字范围是0-2^31,int第一位是符号位,这里用不到,后面一共31位,因此从30到0,自己体会 int u=(x>>i&1);//提取出x的某一位二进制 if(son[p][u]==0)//如果当前位没存son[p][u]=++idx; p=son[p][u]; } }int search(int x){//搜寻能使得和当前x异或最大的数字 int p=0,res=0;//res是最大的结果值 for(int i=30;i>=0;i--){int u=(x>>i&1);//获得当前x二进制位的数字(从高到低)if(son[p][!u]){//如果和该位置 ! (非)存在,注意这里是!//那么就按照这条路走,并更新值res+=(1<//如果该位置没有可以!的 //那么不用res+=,因为该位结果是0,不需要加p=son[p][u];//没办法,只能按照u走,不能按照!u走 }}return res;
} int main(){int n;cin>>n;for(int i=1;i<=n;i++){cin>>a[i];insert(a[i]);}		int ans=0;for(int i=1;i<=n;i++){ans=max(ans,search(a[i]));}cout<

注意
犯了一个很笨比的错误
将!用成了~
!是反转其操作数,用于将0->1, 1->0, 隐式地将true和false转化
而~是按位取反 对于 ~0 ,按位取反后是11111… 值是-1(符号位)
太笨比了,确实数值转化没仔细学过

相关内容

热门资讯

安卓系统如何安装windows... 亲爱的安卓用户们,你是否曾幻想过在手机上体验Windows 7的韵味?别再羡慕那些拥有Windows...
旧的安卓系统怎么备份,轻松保存... 亲爱的安卓用户们,你是否曾经因为系统升级或者手机意外重启而担心丢失了珍贵的照片、联系人或者应用数据呢...
安卓手机系统文件被破坏,全面解... 手机突然间罢工了,是不是很崩溃?别急,今天就来聊聊安卓手机系统文件被破坏的那些事儿。相信我,掌握了这...
街头霸王四安卓系统,畅享格斗盛... 你知道吗?最近在安卓系统上,有一款游戏可是火得一塌糊涂,那就是《街头霸王四》!这款经典格斗游戏在安卓...
阿里tv安卓系统刷机,畅享智能... 你有没有发现,家里的阿里TV用久了,系统有点卡卡的呢?别急,今天就来教你怎么给它来个焕然一新的刷机大...
安卓系统公共文件在哪里,安卓系... 你有没有遇到过这种情况:手机里存了好多文件,但是就是找不到它们在哪里?别急,今天就来给你揭秘安卓系统...
自制安卓系统平板电脑,性能与创... 亲爱的读者们,你是否厌倦了市面上的平板电脑千篇一律?想要拥有一台独一无二的自制安卓系统平板电脑吗?那...
solo3安卓系统能用,体验升... 你有没有听说最近安卓系统界的一个大新闻?那就是solo3安卓系统竟然可以完美兼容各种设备,简直是安卓...
tv版安卓破系统卸,轻松恢复纯... 你有没有遇到过这种情况?手机里的安卓系统突然变得不正常了,各种卡顿、崩溃,让人头疼不已。别急,今天就...
山寨windows平板装安卓系... 你有没有想过,那些看似普通的山寨Windows平板,竟然能装上安卓系统?听起来是不是有点不可思议?别...
安卓车机系统校正,智能驾驶体验... 你有没有发现,你的安卓车机系统有时候就像个不听话的小孩子,时不时地给你点小麻烦?别急,今天就来给你详...
怎样从安卓转移苹果系统,一步到... 你终于下定决心要从安卓转到苹果系统了?这可是个大转变呢!想象你的手机从此将拥有更加流畅的体验、更强大...
安卓变成ios系统软件,系统软... 你知道吗?最近有个大新闻在科技圈里炸开了锅,那就是安卓手机竟然要变成iOS系统软件了!是不是觉得有点...
凤凰安卓系统不能进入,探究原因... 最近是不是有不少小伙伴在使用凤凰安卓系统时遇到了一个让人头疼的问题——就是系统突然不能进入了?别急,...
手机怎么不卡安卓系统,安卓系统... 手机卡顿真是让人头疼啊!尤其是安卓系统,有时候感觉就像老牛拉破车,慢吞吞的。别急,今天就来给你支几招...
安卓系统内存怎么选择好,如何挑... 你有没有想过,为什么你的安卓手机有时候会卡得像蜗牛呢?其实,这跟你的手机内存选择有很大关系哦!今天,...
安卓系统怎么打开键盘,安卓系统... 你是不是在用安卓手机,突然发现键盘怎么也打不开了呢?别急,让我来给你详细介绍安卓系统打开键盘的几种方...
安卓原生精简系统哪个好,哪款更... 你有没有想过,手机系统就像是我们衣橱里的衣服,有时候太多太花哨,反而让人感到繁琐。今天,咱们就来聊聊...
国内哪个安卓系统最好,引领智能... 你有没有想过,手机里的安卓系统就像是我们生活中的各种品牌,各有各的特色和魅力呢?今天,就让我带你来一...
安卓4.2系统下载安装,安卓4... 你有没有想过,你的安卓手机是不是该升级一下系统了呢?别看它现在还能用,但有时候真的有点卡顿,不是吗?...