P10471 最大异或对 The XOR Largest Pair

题意分析

n个数字,从中选2个,使得这二者按位异或的结果最大,求最大值。

求解思路

异或的操作,不同为1,相同为0。

对于数x的二进制,当某一位为0时,查找是否有当前为为1的,如果有即选择当前为为1的这些数。

可以将n个数建立一个trie数,对于数x的每一位,x的当前位为0,则看当前节点是否有1的子节点,如果有则走向值为1的子节点,没有就继续向下走。

细化来看

目标 :A 异或 B 结果最大
贪心原则 :二进制数的高位权重远大于低位。为了让结果最大,我们要尽可能让高位变成 1。→ 从高位开始

我们希望找到一个数B ,使得 B的当前位是1-b (即与 b当前位 不同)。

对于 Trie 中当前位b

  • 存在走向 1−b 的子节点 ,走这条路(能让当前位异或结果为 1,贡献最大值)。
  • 如果不存在只能走 b 这条路(当前位异或结果为 0,虽然不完美,但为了继续匹配低位,只能妥协)。

代码实现

这是我的初代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+10;
int a[N],trie[N][2],cnt=1,maxn=0;
void insert(int x)
{
	int p=1;
	for(int i=31;i>=0;i--)
	{
		int b=(x>>i)&1;
		if(!trie[p][b])
			trie[p][b]=++cnt;
		p=trie[p][b];
	}
}
int query(int x)
{
	int p=1;
	int res=0;
	for(int i=31;i>=0;i--)
	{
		int b=(x>>i)&1;
		if(trie[p][!b])  //走相反的方向,有数
		{
			res=res| (1<<i);//这一位的结果是1 
			p=trie[p][!b]; 
		}
		else p=trie[p][b];
	}
	return res;
}
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++) 
	{
		cin>>a[i];	
		insert(a[i]);
	 } 
	for(int i=1;i<=n;i++)
	{
		maxn=max(maxn,query(a[i]));
	}
	cout<<maxn;
	return 0;
}

只有80分,re了!
原因每个数最多贡献 31 个节点,总节点数约为N×31 。原数组太小导致越界 RE。

正确代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=(1e5+10)*31;
int a[N],trie[N][2],cnt=1,maxn=0;
void insert(int x)
{
	int p=1;
	for(int i=31;i>=0;i--)
	{
		int b=(x>>i)&1;
		if(!trie[p][b])
			trie[p][b]=++cnt;
		p=trie[p][b];
	}
}
int query(int x)
{
	int p=1;
	int res=0;
	for(int i=31;i>=0;i--)
	{
		int b=(x>>i)&1;
		if(trie[p][!b])  //走相反的方向,有数
		{
			res=res| (1<<i);//这一位的结果是1 
			p=trie[p][!b]; 
		}
		else p=trie[p][b];
	}
	return res;
}
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++) 
	{
		cin>>a[i];	
		insert(a[i]);
	 } 
	for(int i=1;i<=n;i++)
	{
		maxn=max(maxn,query(a[i]));
	}
	cout<<maxn;
	return 0;
}
相关推荐
米粒14 小时前
力扣算法刷题 Day 27
算法·leetcode·职场和发展
Fuxiao___5 小时前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#
漫随流水5 小时前
c++编程:反转字符串(leetcode344)
数据结构·c++·算法
穿条秋裤到处跑7 小时前
每日一道leetcode(2026.03.31):字典序最小的生成字符串
算法·leetcode
CoovallyAIHub9 小时前
VisionClaw:智能眼镜 + Gemini + Agent,看一眼就能帮你搜、帮你发、帮你做
算法·架构·github
CoovallyAIHub9 小时前
低空安全刚需!西工大UAV-DETR反无人机小目标检测,参数减少40%,mAP50:95提升6.6个百分点
算法·架构·github
CoovallyAIHub9 小时前
IEEE Sensors | 湖南大学提出KGP-YOLO:先定位风电叶片再检测缺陷,三数据集mAP均超87%
算法
Yupureki10 小时前
《算法竞赛从入门到国奖》算法基础:动态规划-路径dp
数据结构·c++·算法·动态规划
副露のmagic10 小时前
数组章节 leetcode 思路&实现
算法·leetcode·职场和发展
荣光属于凯撒10 小时前
P2176 [USACO11DEC] RoadBlock S / [USACO14FEB] Roadblock G/S
算法·图论