Zeus 和 Prometheus 做了一个游戏,Prometheus 给 Zeus 一个集合,集合中包含了N个正整数,随后 Prometheus 将向 Zeus 发起M次询问,每次询问中包含一个正整数 S ,之后 Zeus 需要在集合当中找出一个正整数 K ,使得 K 与 S 的异或结果最大。Prometheus 为了让 Zeus 看到人类的伟大,随即同意 Zeus 可以向人类求助。你能证明人类的智慧么? 

Input输入包含若干组测试数据,每组测试数据包含若干行。 
输入的第一行是一个整数T(T < 10),表示共有T组数据。 
每组数据的第一行输入两个正整数N,M(<1=N,M<=100000),接下来一行,包含N个正整数,代表 Zeus 的获得的集合,之后M行,每行一个正整数S,代表 Prometheus 询问的正整数。所有正整数均不超过2^32。Output对于每组数据,首先需要输出单独一行”Case #?:”,其中问号处应填入当前的数据组数,组数从1开始计算。 
对于每个询问,输出一个正整数K,使得K与S异或值最大。Sample Input

2
3 2
3 4 5
1
5
4 1
4 6 5 6
3

Sample Output

Case #1:
4
3
Case #2:
4

题意:

给出n个数a[],然后给出m个问题Y,求a[]里面的X,有X xor Y最大。

字典树的作用之一----最大异或:

如果找一个数的最大异或,当然需要从高位到低位(已转化为二进制),尽可能不同。

  • 那么我们从高位到低位表示一个数X,并且存入字典树中,结尾节点记录X(不同的数结尾肯定不同)。
  • 对于询问,从高位到地位先尽可能从兄弟边走。

这可Trie树高度为32,复杂度在接受范围内。

#include<cstdio>
#include<cstdlib>
#include<iostream>
#include<cmath>
#include<algorithm>
#include<cstring>
using namespace std;
const int maxn=;
inline int read()
{
int res=;char x=getchar();while(x<''||x>'') x=getchar();
while(x>=''&&x<=''){ res=res*+x-'';x=getchar();}return res;
}
int q_pow(int a,int x){ int res=;while(x){ if(x&) res*=a; x>>=; a=a*a;} return res; }
struct TREE
{
int ch[maxn][],cnt,num[maxn];
void init() { memset(ch,,sizeof(ch));cnt=;}
void insert(int s[],int val)
{
int Now=;
for(int i=;i>=;i--){
if(!ch[Now][s[i]]) ch[Now][s[i]]=++cnt;
Now=ch[Now][s[i]];
} num[Now]=val;
}
int query(int s[])
{
int Now=;
for(int i=;i>=;i--){
if(ch[Now][s[i]^]) Now=ch[Now][s[i]^];
else Now=ch[Now][s[i]];
} return num[Now];
}
}Tree;
int main()
{
int T,n,m,x,tx,a[],Case=;
scanf("%d",&T);
while(T--){
printf("Case #%d:\n",++Case);
scanf("%d%d",&n,&m);
Tree.init();
for(int i=;i<=n;i++){
scanf("%d",&x);tx=x;
for(int j=;j<=;j++) {
a[j]=x%; x>>=;
} Tree.insert(a,tx);
}
for(int i=;i<=m;i++) {
scanf("%d",&x);
for(int j=;j<=;j++) {
a[j]=x%; x>>=;
} printf("%d\n",Tree.query(a));
}
}return ;
}

兄弟题目:Find MaxXorSum ,这个题求最大异或结果。

所以不需要记录来自于那个数字,记录下和即可。

#include<cstdio>
#include<cstdlib>
#include<iostream>
#include<cmath>
#include<algorithm>
#include<cstring>
using namespace std;
const int maxn=;
inline int read()
{
int res=;char x=getchar();while(x<''||x>'') x=getchar();
while(x>=''&&x<=''){ res=res*+x-'';x=getchar();}return res;
}
int q_pow(int a,int x){ int res=;while(x){ if(x&) res*=a; x>>=; a=a*a;} return res; }
struct TREE
{
int ch[maxn][],cnt;
void init() { memset(ch,,sizeof(ch));cnt=;}
void insert(int s[])
{
int Now=;
for(int i=;i>=;i--){
if(!ch[Now][s[i]]) ch[Now][s[i]]=++cnt;
Now=ch[Now][s[i]];
}
}
int query(int s[])
{
int Now=,res=;
for(int i=;i>=;i--){
if(ch[Now][s[i]^]) Now=ch[Now][s[i]^],res+=q_pow(,i);
else if(ch[Now][s[i]]) Now=ch[Now][s[i]];
else break;
} return res;
}
}Tree;
int main()
{
int T,n,i,j,a[],b[],tmp,ans;
scanf("%d",&T);
while(T--){
Tree.init(); ans=; scanf("%d",&n);
for(i=;i<=n;i++){
scanf("%d",&a[i]); tmp=a[i];
for(j=;j<=;j++) {
b[j]=tmp%; tmp>>=;
} Tree.insert(b);
}
for(i=;i<=n;i++) {
for(j=;j<=;j++) {
b[j]=a[i]%; a[i]>>=;
} ans=max(ans,Tree.query(b));
} printf("%d\n",ans);
}return ;
}

HDU4825 Xor Sum(字典树解决最大异或问题)的更多相关文章

  1. HDU--4825 Xor Sum (字典树)

    题目链接:HDU--4825 Xor Sum mmp sb字典树因为数组开的不够大一直wa 不是报的 re!!! 找了一下午bug 草 把每个数转化成二进制存字典树里面 然后尽量取与x这个位置上不相同 ...

  2. HDU4825 Xor Sum —— Trie树

    题目链接:https://vjudge.net/problem/HDU-4825 Xor Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Li ...

  3. 2014百度之星第三题Xor Sum(字典树+异或运算)

    Xor Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 132768/132768 K (Java/Others) Total ...

  4. HDU 4825 Xor Sum 字典树+位运算

    点击打开链接 Xor Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 132768/132768 K (Java/Others) ...

  5. hdu 4825 xor sum(字典树+位运算)

    Xor Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 132768/132768 K (Java/Others)Total S ...

  6. AcWing:143. 最大异或对(01字典树 + 位运算 + 异或性质)

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

  7. HDU-4825 Xor Sum,字典树好题!

    Xor Sum 一遍A了之后大呼一声好(keng)题!debug了两小时~~~~百度之星资格赛,可以. 题意:给你一个n个元素的数组,m次查询,每次输入一个数k要求从数组中找到一个数与k异或值最大,输 ...

  8. ☆ [HDU4825] Xor Sum「最大异或和(Trie树)」

    传送门:>Here< 题意:给出一个集合,包含N个数,每次询问给出一个数x,问x与集合中的一个数y异或得到最大值时,y是多少? 解题思路 由于N,M非常大,暴力显然不行.抓住重点是异或,所 ...

  9. [Hdu4825]Xor Sum(01字典树)

    Description Zeus 和 Prometheus 做了一个游戏,Prometheus 给 Zeus 一个集合,集合中包含了N个正整数,随后 Prometheus 将向 Zeus 发起M次询问 ...

随机推荐

  1. IOS 后台保持连接

    当iphone应用程序进行网络编程时,切到后台后,socket连接会断掉,ios的设计就是这样. 但是好在apple公司也没有那么绝,还是有一些东西可以在后台运行的(backgroundmodes), ...

  2. [转载] C/C++中怎样获取日期和时间

    C/C++中怎样获取日期和时间摘要:  本文从介绍基础概念入手,探讨了在C/C++中对日期和时间操作所用到的数据结构和函数,并对计时.时间的获取.时间的计算和显示格式等方面进行了阐述.本文还通过大量的 ...

  3. Spin.js-CSS动画进度载入器

    spin.js是一款很easy的CSS载入器,他是一款使用了VML(Vector Makeup Language)的CSS动画效果. spin.js的特性 他有着很强大的适应性.有着下面几个特性: 1 ...

  4. Tyvj3308毒药解药题解

    题目大意 这些药都有可能在治愈某些病症的同一时候又使人患上某些别的病症--经过我天才的努力.最终弄清了每种药的详细性能,我会把每种药能治的病症和能使人患上的病症列一张清单给你们,然后你们要依据这张清单 ...

  5. 解题报告 之 HDU5288 OO&#39; s Sequence

    解题报告 之 HDU5288 OO' s Sequence Description OO has got a array A of size n ,defined a function f(l,r) ...

  6. Solaris服务管理

    远程登录协议 telnet \ssh 等.当然我们可以查看谁登录过我的系统,以及可以利用ftp记录日志. 一.SMF: 服务管理工具 优点:自动恢复意外终止的服务,支持服务的依赖关系,一个服务可以有多 ...

  7. Linux CenOS Python3 和 python2 共存

    1.查看是否已经安装Python CentOS 7.2 默认安装了python2.7.5 因为一些命令要用它比如yum 它使用的是python2.7.5. 使用 python -V 命令查看一下是否安 ...

  8. 解析java.math.BigInteger类——构造函数

    最早由于做作业,结识了java的BigInrger类.读着读着,越来越觉得有趣.后来作业做完,也不忍丢下它,索性把全部代码研究一遍. 开始的时候,一个上午时间最多读懂2个方法.但是还是有滋有味的坚持了 ...

  9. 文件共享和使用 dup 函数创建新描述符的区别

    前言 文件共享是指同时打开一个文件 用 dup 函数能对指定文件描述符再创建一个新的描述符,且这个新的描述符和旧的描述符指向的是同一个文件. 这两种行为有什么区别呢?下面给出的两张文件系统的图形象的解 ...

  10. iOS开发- OpenGL ES屏幕截图

    之前写过一个常规的屏幕截图:http://blog.csdn.net/hitwhylz/article/details/17189351 可是发现这个办法对于OpenGL 无用.  获取到的数据为空. ...