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(符号位)
太笨比了,确实数值转化没仔细学过

相关内容

热门资讯

uu模拟器安卓系统,uu模拟器... 你有没有想过,在手机上玩电脑游戏是多么神奇的事情?想象你可以在小小的手机屏幕上,操控着那些庞大的游戏...
安卓连车载系统吗,创新科技引领... 你有没有想过,你的安卓手机和车载系统之间是不是也能来个亲密接触呢?想象当你开车在路上,手机上的导航、...
安卓换ios系统的感想,系统切... 你知道吗?我最近经历了一次大变身,把我的安卓手机换成了苹果的iOS系统。这可不是一个小决定,毕竟手机...
海尔电视怎么装安卓系统,解锁更... 亲爱的电视迷们,你是否对家里的海尔电视充满了好奇,想要给它来个“大变身”,让它从传统电视摇身一变,成...
安卓系统的几大分别 你知道吗?在智能手机的世界里,安卓系统可是当之无愧的“人气王”呢!它就像一位多才多艺的魔术师,总能变...
安卓机照片导入苹果系统,轻松实... 你有没有想过,把安卓手机里的照片导入到苹果系统里呢?这听起来可能有点复杂,但其实,只要掌握了正确的方...
安卓系统刷成miui系统软件 你有没有想过给你的安卓手机换换口味呢?没错,就是那种焕然一新的感觉!今天,就让我来带你一起探索如何将...
雷鸟安卓系统官网登录,解锁智能... 你有没有听说最近雷鸟安卓系统官网登录变得超级方便啦?没错,就是那个让无数手机用户爱不释手的系统,现在...
安卓系统的tf管理,功能解析与... 你有没有发现,你的安卓手机里藏着一个小秘密?那就是TF卡管理!别小看这个小功能,它可是让你的手机存储...
三星安卓系统转鸿蒙系统,跨越生... 你知道吗?最近有个大动作在手机圈里引起了不小的轰动呢!那就是三星安卓系统转鸿蒙系统的事情。是不是觉得...
安卓是用哪个系统,基于Linu... 你有没有想过,安卓手机里那些炫酷的功能,背后其实都离不开一个强大的系统支撑呢?没错,就是那个让安卓手...
橘子4.0系统是安卓几,深度解... 你有没有听说过橘子4.0系统?最近这个话题在手机圈里可是火得一塌糊涂呢!很多人都在问,这个橘子4.0...
安卓系统解锁文件在哪里,安卓系... 你是不是也和我一样,对安卓系统的解锁文件充满了好奇?想知道这些神秘的文件藏在哪里吗?那就跟着我一起探...
安卓系统为啥不要钱,技术开源的... 你有没有想过,为什么安卓系统这么神奇,竟然不要钱就能用?这背后可是有着不少故事呢,让我们一起揭开这个...
安卓系统播放器apk,安卓系统... 你有没有发现,手机里那个小小的播放器,竟然能承载我们那么多美好的回忆?今天,就让我带你一起探索安卓系...
安卓系统微信突然没了,原因揭秘... 最近我的安卓手机上微信突然不见了,这可真是让人头疼啊!微信可是我日常生活中必不可少的社交工具,这下可...
安卓系统点网页链接,探索便捷信... 你有没有遇到过这种情况?手机里打开了一个网页链接,点进去一看,哇,竟然是安卓系统的页面!是不是瞬间觉...
安卓系统起名好听吗 说到安卓系统,你是不是也和我一样,每次看到那些手机屏幕上跳出来的系统名称,就会忍不住想:这名字听起来...
氢os系统是安卓吗,安卓的革新... 你有没有想过,手机操作系统界最近又出现了一个新面孔——氢OS系统?它和安卓系统有什么关系呢?是不是安...
安卓系统如何改密码,安卓系统密... 手机里的安卓系统密码丢了?别急,让我来给你支个招,让你轻松找回或者重置密码,让你的手机安全无忧!一、...