GYM 100883 E.xortion(字典树)
来源:互联网 发布:数据联邦 编辑:程序博客网 时间:2024/05/02 18:50
Description
给出一个长度为n的序列a[i],q次查询,每次查询给出一个x,求i使得a[i]^x最大
Input
第一行一整数T表示用例组数,每组用例首先输入两个整数n和q表示序列长度和查询数,之后n个整数a[i]表示该序列,最后q行每行一个整数x表示查询(1<=n<=1e5,1<=q<=3e5,a[i],x不会超过32位整型)
Output
对于每次查询,输入最小的i满足a[i]^x最小
Sample Input
1
3 3
3 1 2
4
5
6
Sample Output
1
3
2
Solution
字典树裸题,把所有a[i]拆成32位二进制建字典树,对于每个x,同样拆成32位二进制在字典树上查询,如果当前为是x,则在字典树上找这一层是否有x^1,如果有就从x^1往下一层走,否则只能从x往下一层走,这样找到终点就找到了a[i]使得a[i]^x最大,因为要输出的是下标所以拿map存一下a[i]和i的对应就好
Code
#include<cstdio>#include<iostream>#include<cstring>#include<algorithm>#include<cmath>#include<vector>#include<queue>#include<map>#include<set>#include<ctime>using namespace std;typedef long long ll;#define INF 0x3f3f3f3f#define maxn 111111int chd[maxn*32][2],nn=0,num[maxn*32];void init(){ nn=1; memset(chd[0],-1,sizeof(chd[0]));}void insert(int x){ int p=0; for(int i=31;i>=0;i--) { int t=(x>>i)&1; if(chd[p][t]==-1) { chd[p][t]=nn; memset(chd[nn],-1,sizeof(chd[nn])); nn++; } p=chd[p][t]; }}int find(int x){ int p=0; int ret=0; for(int i=31;i>=0;i--) { int t=((x>>i)&1)^1; if(chd[p][t]==-1)t^=1; p=chd[p][t]; ret<<=1; ret|=t; } return ret;}map<int,int>M; int T,n,q;int main(){ int res=0; scanf("%d",&T); while(T--) { init(); M.clear(); scanf("%d%d",&n,&q); for(int i=1;i<=n;i++) { int a; scanf("%d",&a); if(M.find(a)==M.end())M[a]=i,insert(a); } while(q--) { int a; scanf("%d",&a); printf("%d\n",M[find(a)]); } if(T)printf("\n"); } return 0;}
0 0
- GYM 100883 E.xortion(字典树)
- GYM 101086 C.Everything(字典树)
- E - Repository (字典树)
- gym 100935B (字典树)
- Gym 100499E (树DP)
- Gym 100962E Elvis Presley (二叉树模拟 + set)
- Gym-101612E E
- Codeforces Gym-101161E【LCA+主席树】
- Gym 101161E 主席树+LCA
- GYM 100030 E.Tests Preparation(枚举)
- GYM 100090 E.Counterfeiters(概率)
- GYM 100182 E.Minesweeper(水~)
- GYM 101128 E.Wooden Signs(dp)
- GYM 100712 E.Epic Professor(水~)
- GYM 101147 E.Jumping(SPFA)
- GYM 100694 E.SuperHyperMarket(set)
- gym 101196E Red Rover(枚举)
- codeforces 665E (字典树)
- 数据结构与算法in C&C++(1)/SWAP
- 文章标题
- 补间动画的实现
- Java动态代理深入解析
- python 的lambda
- GYM 100883 E.xortion(字典树)
- MXNet设计笔记之:深度学习的编程模式比较
- 自定义dialog
- Java String 类
- 获取主页面发送给二级页面的url地址
- cocos2d里的法线贴图
- Android6.0来电流程
- train_test_split(X, y, stratify=y)
- Matlab标定工具箱使用教程