ZYB loves Xor I HDU - 5269 字典树
题意:
T组样例,给你n个数。你要找出来这n个数中任意两个数的二进制位中 最低位不同 的位置(假设是k),然后让所有2^k加起来就是结果
什么意思?
例如4 和 2
4的二进制是(100),2的二进制是(010),那么它们二进制位中 最低位不同 的位置 就是1,然后把这个2^1加入最后结果就完了
注意:4和2算一次结果,2和4也要算一次结果
解释个样例:
5
4 0 2 7 0
sum=0
4和0:k=2,sum+=2^2
4和2:k=1,sum+=2^1
4和7:k=0,sum+=2^0
4和0:k=2,sum+=2^2
0和2:k=1,sum+=2^1
0和7:k=0,sum+=2^0
0和0:因为0^0=0,题目上lowbit(0)=0,所以sum+=0
2和7:k=0,sum+=2^0
2和0:k=1,sum+=2^1
7和0:k=0,sum+=2^0
sum=4+2+1+4+2+1+0+1+2+1=18
又因为“4和2算一次结果,2和4也要算一次结果”,所以sum*=2
sum=36
题解:
观察发现对于任意一个数 x 来说,只要前 i-1 位和其它数相等,第i位不相等。那么 ans += cnt * pow(2, i-1);
cnt 为和它前i-1个前缀都相等的数的个数。 可以利用字典树边插入边更新ans,最后ans*2就是答案。
数组开小了TLE了半天。。。。
代码:
1 #include <iostream>
2 #include <cstdio>
3 #include <cstring>
4 #include <cstdlib>
5 #include <algorithm>
6 using namespace std;
7 typedef long long ll;
8 const int maxn=2;
9 const ll mod=998244353;
10 typedef struct Trie* TrieNode;
11 ll v[50005];
12 ll w[31],result;
13 struct Trie
14 {
15 ll val,sum;
16 TrieNode next[2];
17 Trie()
18 {
19 val=0;
20 sum=0;
21 memset(next,NULL,sizeof(next));
22 }
23 };
24
25 void inserts(TrieNode root,ll x,ll y)
26 {
27 TrieNode p = root;
28 for(ll i=0;i<30;++i)
29 {
30 ll temp=(x>>i)&1;
31 if(p->next[temp]==NULL) p->next[temp]=new struct Trie();
32 if(p->next[!temp]!=NULL && p->next[!temp]->sum>0)
33 {
34 ll t=p->next[!temp]->sum;
35 t=(t*(ll)w[i])%mod;
36 result=(result+t)%mod;
37 }
38 p->next[temp]->sum+=y;
39 p=p->next[temp];
40 }
41 p->val=x;
42 }
43 void Del(TrieNode root)
44 {
45 for(ll i=0 ; i<2 ; ++i)
46 {
47 if(root->next[i])Del(root->next[i]);
48 }
49 delete(root);
50 }
51
52 int main()
53 {
54 ll t,n,sum=1;
55 int p=0;
56 w[0]=1;
57 for(int i=1;i<=30;++i)
58 {
59 sum=(sum*2)%mod;
60 w[i]=sum;
61 }
62 scanf("%lld",&t);
63 while(t--)
64 {
65 TrieNode root = new struct Trie();
66 scanf("%lld",&n);
67 //ll ans=0;
68 result=0;
69 for(ll i=1;i<=n;++i)
70 {
71 scanf("%lld",&v[i]);
72 inserts(root,v[i],1);
73 }
74 printf("Case #%d: %lld\n",++p,(result<<1)%mod);
75 Del(root);
76 }
77 return 0;
78 }
ZYB loves Xor I HDU - 5269 字典树的更多相关文章
- HDU--5269 ZYB loves Xor I (字典树)
题目电波: HDU--5269 ZYB loves Xor I 首先我们先解决 ai xor aj 每个数转化为二进制 我们用字典树统计 每个节点 0 和 1 的出现的个数 #include< ...
- ZYB loves Xor I(hud5269)
ZYB loves Xor I Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- hdu 5269 ZYB loves Xor I
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submission( ...
- HDU 4825 Xor Sum(01字典树入门题)
http://acm.hdu.edu.cn/showproblem.php?pid=4825 题意: 给出一些数,然后给出多个询问,每个询问要从之前给出的数中选择异或起来后值最大的数. 思路:将给出的 ...
- hdu 4825 Xor Sum(01字典树模版题)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4825 题解:一到01字典树的模版题,01字典树就是就是将一些树用二进制放到一个树上这样可以方便对整体异 ...
- HDU 4825 Xor Sum(01字典树)题解
思路:先把所有数字存进字典树,然后从最高位贪心. 代码: #include<set> #include<map> #include<stack> #include& ...
- HDU 4825 Xor Sum (裸字典树+二进制异或)
题目链接 Problem Description Zeus 和 Prometheus 做了一个游戏,Prometheus 给 Zeus 一个集合,集合中包含了N个正整数,随后 Prometheus 将 ...
- Chip Factory HDU - 5536 字典树(删除节点|增加节点)
题意: t组样例,对于每一组样例第一行输入一个n,下面在输入n个数 你需要从这n个数里面找出来三个数(设为x,y,z),找出来(x+y)^z(同样也可以(y+z)^1)的最大值 ("^&qu ...
- HDU 5687 字典树插入查找删除
题目:http://acm.hdu.edu.cn/showproblem.php?pid=5687 2016百度之星资格赛C题,直接套用字典树,顺便巩固了一下自己对字典树的理解 #include< ...
随机推荐
- Sentry(v20.12.1) K8S 云原生架构探索,JavaScript 性能监控之管理 Transactions
系列 Sentry-Go SDK 中文实践指南 一起来刷 Sentry For Go 官方文档之 Enriching Events Snuba:Sentry 新的搜索基础设施(基于 ClickHous ...
- Q-Q图原理详解及Python实现
[导读]在之前的<数据挖掘概念与技术 第2章>的文章中我们介绍了Q-Q图的概念,并且通过调用现成的python函数, 画出了Q-Q图, 验证了Q-Q图的两个主要作用,1. 检验一列数据是否 ...
- 推荐大家去撸60元的阿里云ACA DevOps认证
要试题的右边扫码支付10元,私聊博客哈,说出你微信号,留下邮箱,发你邮箱Pdf文件,这么便宜拿证!!
- Graceful restart of a server with active WebSocket
Graceful restart of a server with active WebSocket Simonwep/graceful-ws: ⛓ Graceful WebSocket wrappe ...
- 算法总结篇---KMP算法
目录 写在前面 例题 剪花布条 Radio Transmission OKR-Periods of Words 似乎在梦中见过的样子 Censoring 写在前面 仅为自用,不做推广 一起来看猫片吧! ...
- Language Guide (proto3) | proto3 语言指南(十三)JSON映射
JSON Mapping - JSON映射 Proto3支持JSON中的规范编码,使得在系统之间共享数据更加容易.下表按类型对编码进行了描述. 如果JSON编码的数据中缺少一个值或者它的值为null, ...
- 项目管理/Bug管理/问题管理—Phabricator
项目管理/Bug管理/问题管理-Phabricator 1.项目管理/Bug管理/问题管理工具 2.Phabricator 3.Docker 方式安装Phabricator 3.1Docker方式安装 ...
- Java——I/O入门相关练习代码
流的概念 读取文件 读取文件1 读取文件2 读取文件3 读取文件4 skip跳过n个字节后再开始读取 读取过程中暂停给当前位置做一个标记下一次从标记位置开始读取 序列流集合流 把三个流添加到集合中合并 ...
- Django(自定义过滤器和自定义标签)
模版是一个用django模版语言标记过的python字符串.模版可以包含模版标签和变量. 模版标签是在一个模版里起作用的标记.比如,一个模版标签可以产生控制结构的内容(if或者for),可以获取数据库 ...
- docker 安装 nexus3 初始密码不再是admin123
最近在docker上安装 nexus3 ,参照之前博客都提示 初始密码是admin/admin123 但是登录的时候出现如下提示: 很显然提示 admin用户的密码在/nexus-data/admi ...