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次询问 ...
随机推荐
- NHibernate剖析:Mapping篇之Mapping-By-Code(1):概览
ModelMapper概述 NHibernate3.2版本号集成Mapping-By-Code(代码映射),其设计思想来源于ConfORM.代码总体构思基于"Loquacious" ...
- MySQL双主热备问题处理
1. Slave_IO_Running: No mysql> show slave status\G *************************** 1. row *********** ...
- Linux基础(1)- 命令和目录文件
1.开启Linux操作系统,要求以root用户登录GNOME图形界面,语言支持选择为汉语 Linux操作界面如图: 右击桌面,点击打开终端 输入“su”,点击回车键,出现密码,输入密码,点击回车键,显 ...
- 第14章8节《MonkeyRunner源代码剖析》 HierarchyViewer实现原理-获取控件列表并建立控件树
在上几节的描写叙述中,我们把HierarchyViewer初始化好.也把ViewServer给装备好了.那如今距离获得一个控件去操作它是万事具备仅仅欠东风了,欠了那一股春风了?欠了的是建立控件树这个东 ...
- bat+sqlcmd 批量执行脚本
Hello,此BAT脚本能够帮助开发者将某目录下全部SQL脚本按文件名称依次在指定数据库中批量执行. 不用忍受powershell invoke-sqlcmd 的笨重.在指执行时多一种选择. bat文 ...
- oracle sql修改序列为当前序列开始
declare v_num integer; last_value integer;Begin select SEQ_TBM_ID.NEXTVAL into last_value from d ...
- Cisco策略路由(policy route)精解(转载)
原文:http://www.guanwei.org/post/Cisconetwork/07/Cisco-policy-route_8621.html 注:PBR以前是CISCO用来丢弃报文的一个主要 ...
- SQL还有多少"理所当然";还有那些"就是这样"
前言废话——sql是程序员的饭碗,繁琐but万能,但能干并不意味着适合干,每当多表关联寻找外键时,我都在经历一种没有选择的痛苦.sql不完美,但长期代码让人无暇顾及完美,再痛苦的呐喊到最后都归于疲倦已 ...
- iOS开发之NewsstandKit.framework的使用
本文转载至 http://mobile.51cto.com/iphone-423385.htm 系统提供NewsstandKit.framework来支持newsstand类型的程序,就是在spr ...
- 【BZOJ2625】[Neerc2009]Inspection 最小流
[BZOJ2625][Neerc2009]Inspection Description You are in charge of a team that inspects a new ski reso ...