HDU4825 Xor Sum(字典树解决最大异或问题)
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(字典树解决最大异或问题)的更多相关文章
- HDU--4825 Xor Sum (字典树)
题目链接:HDU--4825 Xor Sum mmp sb字典树因为数组开的不够大一直wa 不是报的 re!!! 找了一下午bug 草 把每个数转化成二进制存字典树里面 然后尽量取与x这个位置上不相同 ...
- HDU4825 Xor Sum —— Trie树
题目链接:https://vjudge.net/problem/HDU-4825 Xor Sum Time Limit: 2000/1000 MS (Java/Others) Memory Li ...
- 2014百度之星第三题Xor Sum(字典树+异或运算)
Xor Sum Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Others) Total ...
- HDU 4825 Xor Sum 字典树+位运算
点击打开链接 Xor Sum Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Others) ...
- hdu 4825 xor sum(字典树+位运算)
Xor Sum Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Others)Total S ...
- AcWing:143. 最大异或对(01字典树 + 位运算 + 异或性质)
在给定的N个整数A1,A2……ANA1,A2……AN中选出两个进行xor(异或)运算,得到的结果最大是多少? 输入格式 第一行输入一个整数N. 第二行输入N个整数A1A1-ANAN. 输出格式 输出一 ...
- HDU-4825 Xor Sum,字典树好题!
Xor Sum 一遍A了之后大呼一声好(keng)题!debug了两小时~~~~百度之星资格赛,可以. 题意:给你一个n个元素的数组,m次查询,每次输入一个数k要求从数组中找到一个数与k异或值最大,输 ...
- ☆ [HDU4825] Xor Sum「最大异或和(Trie树)」
传送门:>Here< 题意:给出一个集合,包含N个数,每次询问给出一个数x,问x与集合中的一个数y异或得到最大值时,y是多少? 解题思路 由于N,M非常大,暴力显然不行.抓住重点是异或,所 ...
- [Hdu4825]Xor Sum(01字典树)
Description Zeus 和 Prometheus 做了一个游戏,Prometheus 给 Zeus 一个集合,集合中包含了N个正整数,随后 Prometheus 将向 Zeus 发起M次询问 ...
随机推荐
- Android重写view时onAttachedToWindow () 和 onDetachedFromWindow ()
在重写View的时候,会遇到这两个方法 protected void onAttachedToWindow() Description copied from class: View This is ...
- 赞一下TMS Software 和 AdvStringGrid
非常久前给Support发Email问能不能在设计期给AdvStringGrid标题加个数字标识.每次我都是自己改代码加上去.这次升级到新版本号,没想到增加了这个功能: 功能虽小可是非常有用,非常多的 ...
- gulp(基础篇)
今天在写项目的时候用到了gulp构建工具,虽然一年前就有用过,但是一直只存在于我的“有道云笔记”里,今天又一次用到,固然是巩固一下,这里来记录一下吧:这里我主要想要记录的就是初学者在第一次使用gulp ...
- OI知识体系
- eclipse的快捷键(常用)
1. Ctrl+O 显示类中方法和属性的大纲,能快速定位类的方法和属性,在查找Bug时非常有用. 2. Ctrl+M 窗口最大化和还原,用户在窗口中进行操作时,总会觉得当前窗口小(尤其在编写代码时), ...
- vim tips 集锦
删除文件中的空行 :g/^$/d g 表示 global,全文件 ^ 是行开始,$ 是行结束 d 表示删除该 这里只能匹配到没有白空符的空行,假如要删除有空白符的空行,则使用: :g/^\s*$/d ...
- Android组件系列----ContentProvider内容提供者【4】
(4)单元測试类: 这里须要涉及到另外一个知识:ContentResolver内容訪问者. 要想訪问ContentProvider.则必须使用ContentResolver. 能够通过ContentR ...
- properties配置文件读取
1.配置文件test.properties: test_123=admin 注:value 可用单引号,双引号,不用引号修饰 2.工具类PropertiesUtil: package com..... ...
- STL_算法_查找算法(find、find_if)
C++ Primer 学习中. .. 简单记录下我的学习过程 (代码为主) find . find_if /**********************线性查找O(n) find(); find_if ...
- android arcmenu
http://www.kankanews.com/ICkengine/archives/129193.shtml