[cf1261F]Xor-Set
构造一棵权值范围恰为$[0,2^{60})$的权值线段树,考虑其中从下往上第$h$层($0\le h\le 60$)中的一个区间,假设其左端点为$l$,即$[l,l+2^{h})$
这样的一个区间具有一个很好的性质,其是按位独立的,即其等价于二进制下最高的$60-h$位与$l$相同,剩下的$h$位任意的数所构成的集合
对于这样的两个集合$[l_{1},l_{1}+2^{h_{1}})$和$[l_{2},l_{2}+2^{h_{2}})$合并的结果,也就是最高的$60-\max(h_{1},h_{2})$位与$l_{1}\oplus l_{2}$相同,剩下的$\max(h_{1},h_{2})$位任意的数所构成的集合,证明利用按位独立的性质分析即可
更具体的,合并结果对应于区间$[l_{3},l_{3}+2^{\max(h_{1},h_{2})})$,其中$l_{3}=(l_{1}\oplus l_{2})\and (2^{60}-2^{\max(h_{1},h_{2})}))$(后者的意义即取$l_{1}\oplus l_{2}$二进制下最高的$60-\max(h_{1},h_{2})$位)
考虑将$n_{a}$和$n_{b}$个区间分别插入线段树,划分为$\log V$个线段树上区间(即分别有$n_{a}\log V$和$n_{b}\log V$个区间),将其两两按上述方法合并,再对最终的区间快排,复杂度即$o(n^{2}\log^{3}V)$(其中$V$为值域,即$10^{18}$)
这样的复杂度是不能接受的,需要进行优化
对于这个合并的结果(不妨假设$h_{1}\ge h_{2}$),等价于$[l_{1},l_{1}+2^{h_{1}})$与$[l_{3},l_{3}+2^{h_{1}})$(其中$l_{3}=l_{2}\and(2^{60}-2^{h_{1}})$),在线段树上也就是$[l_{2},l_{2}+2^{h_{2}})$这个区间所对应的节点在从下往上第$h_{1}$层的祖先
(以$n_{a}$个区间为例)定义一个节点被标记即其是$n_{a}\log V$个区间中的一个,将所有节点分为三类:
1.其自身被标记
2.其自身未被标记且其子树内存在节点被标记
3.其子树内(包括自身)无节点被标记
类似地,对于$n_{b}\log V$个区间也可以得到节点类型,那么也就可以看作$n_{a}\log V$个区间中1类节点和$n_{b}\log V$个区间中的2类节点两两合并以及前者的2类节点和后者的1类节点两两合并
(关于原因可以参考前面的说明,也就是将所有节点先提到同一层)
对于这样的复杂度,分别考虑每一层第1类和第2类节点个数:
1.第1类节点,也就是被严格包含,但如果其与其兄弟同时被包含即不需要被插入,同时被包含的节点必然是连续若干个,那么至多两个(否则必然存在兄弟)
2.第2类节点,也就是线段树在递归过程中经过且未结束的节点,更具体的即有交点但不被包含,显然每一次插入后每一层至多新增两个(最左边和最右边)
综上,每一层两类的节点数都是$o(n)$的,那么每一层合并复杂度为$o(n^{2})$,总区间个数降为$o(n^{2}\log V)$,再对其排序复杂度即$o(n^{2}\log^{2}V)$,可以通过
1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 105
4 #define mod 998244353
5 #define ll long long
6 #define mid (l+r>>1)
7 #define pll pair<ll,ll>
8 #define fi first
9 #define se second
10 pll a[8*N*N*N];
11 vector<ll>v[4][N];
12 int V,rt,n,na,nb,ans,ls[4*N*N],rs[4*N*N];
13 ll m,x,y;
14 int sum(ll x,ll y){
15 int s1=(x+y)%mod,s2=(y-x+1)%mod;
16 return 1LL*s1*s2%mod*(mod+1)/2%mod;
17 }
18 void update(int p,int &k,ll l,ll r,ll x,ll y,int z){
19 if ((l>y)||(x>r))return;
20 if (!k)k=++V;
21 if ((x<=l)&&(r<=y)){
22 v[p][z].push_back(l);
23 return;
24 }
25 v[p+2][z].push_back(l);
26 update(p,ls[k],l,mid,x,y,z-1);
27 update(p,rs[k],mid+1,r,x,y,z-1);
28 }
29 int main(){
30 m=(1LL<<60)-1;
31 scanf("%d",&na);
32 for(int i=1;i<=na;i++){
33 scanf("%lld%lld",&x,&y);
34 update(0,rt,0,m,x,y,60);
35 }
36 scanf("%d",&nb);
37 for(int i=1;i<=nb;i++){
38 scanf("%lld%lld",&x,&y);
39 update(1,rt,0,m,x,y,60);
40 }
41 for(int i=0;i<=60;i++){
42 for(int j=0;j<v[0][i].size();j++)
43 for(int k=0;k<v[1][i].size();k++){
44 x=(v[0][i][j]^v[1][i][k]);
45 a[++n]=make_pair(x,x+(1LL<<i)-1);
46 }
47 for(int j=0;j<v[0][i].size();j++)
48 for(int k=0;k<v[3][i].size();k++){
49 x=(v[0][i][j]^v[3][i][k]);
50 a[++n]=make_pair(x,x+(1LL<<i)-1);
51 }
52 for(int j=0;j<v[1][i].size();j++)
53 for(int k=0;k<v[2][i].size();k++){
54 x=(v[1][i][j]^v[2][i][k]);
55 a[++n]=make_pair(x,x+(1LL<<i)-1);
56 }
57 }
58 sort(a+1,a+n+1);
59 ll s=0;
60 for(int i=1;i<=n;i++){
61 if (a[i].fi>s)ans=(ans+sum(a[i].fi,a[i].se))%mod;
62 else{
63 if (s<a[i].se)ans=(ans+sum(s+1,a[i].se))%mod;
64 }
65 s=max(s,a[i].se);
66 }
67 printf("%d",ans);
68 }
[cf1261F]Xor-Set的更多相关文章
- [LeetCode] Maximum XOR of Two Numbers in an Array 数组中异或值最大的两个数字
Given a non-empty array of numbers, a0, a1, a2, … , an-1, where 0 ≤ ai < 231. Find the maximum re ...
- 二分+DP+Trie HDOJ 5715 XOR 游戏
题目链接 XOR 游戏 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total ...
- BZOJ 2115 【Wc2011】 Xor
Description Input 第一行包含两个整数N和 M, 表示该无向图中点的数目与边的数目. 接下来M 行描述 M 条边,每行三个整数Si,Ti ,Di,表示 Si 与Ti之间存在 一条权值为 ...
- xor和gates的专杀脚本
前段时间的一次样本,需要给出专杀,应急中遇到的是linux中比较常见的两个家族gates和xor. 首先是xor的专杀脚本,xor样本查杀的时候需要注意的是样本的主进程和子进程相互保护(详见之前的xo ...
- Codeforces617 E . XOR and Favorite Number(莫队算法)
XOR and Favorite Number time limit per test: 4 seconds memory limit per test: 256 megabytes input: s ...
- Xor && 线性基练习
#include <cstdio> #include <cstring> ; ; int cnt,Ans,b,x,n; inline int Max(int x,int y) ...
- BC之Claris and XOR
http://acm.hdu.edu.cn/showproblem.php?pid=5661 Claris and XOR Time Limit: 2000/1000 MS (Java/Others) ...
- 异或链表(XOR linked list)
异或链表(Xor Linked List)也是一种链式存储结构,它可以降低空间复杂度达到和双向链表一样目的,任何一个节点可以方便的访问它的前驱节点和后继结点.可以参阅wiki 普通的双向链表 clas ...
- hdu 5661 Claris and XOR
Claris and XOR Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)To ...
- [BZOJ 2819]NIM(dfs序维护树上xor值)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2819 分析: 树上的nim游戏,关键就是要判断树上的一条链的异或值是否为0 这个题目有 ...
随机推荐
- NOIP模拟73
T1 小L的疑惑 解题思路 第一眼不是正解,又是 bitset 优化可以得到的 60pts 的部分分. 打着打着突然发现这个东西好像和之前做过的某个题有一些相似,试着打了一下. 然后样例过了,然后对拍 ...
- Xcode相关
Xcode相关的路径 Provisioning Profiles存放路径:~/Library/MobileDevice/Provisioning Profiles 所有模拟器(包括历史模拟器):~/L ...
- 时序数据库InfluxDB的基本语法
一 了解InfluxDB的必要性 时序数据库主要存放的数据 Time series data is a series of data points each associated with a spe ...
- 模拟赛T2 交换 解题报告
模拟赛T2 交换 解题报告 题目大意: 给定一个序列和若干个区间,每次从区间中选择两个数修改使字典序最小. \(n,m\) 同阶 \(10^6\) 2.1 算法 1 按照题意模拟,枚举交换位置并比较. ...
- FastAPI 学习之路(十九)处理错误
系列文章: FastAPI 学习之路(一)fastapi--高性能web开发框架 FastAPI 学习之路(二) FastAPI 学习之路(三) FastAPI 学习之路(四) FastAPI 学习之 ...
- Web前端安全之安全编码原则
随着Web和移动应用等的快速发展,越来越多的Web安全问题逐渐显示出来.一个网站或一个移动应用,如果没有做好相关的安全防范工作,不仅会造成用户信息.服务器或数据库信息的泄露,更可能会造成用户财产的损失 ...
- 264.丑数II
题目 给你一个整数 n ,请你找出并返回第 n 个 丑数 . 丑数 就是只包含质因数 2.3 和/或 5 的正整数. 示例 1: 输入:n = 10 输出:12 解释:[1, 2, 3, 4, 5, ...
- 离线状态迁移Anaconda虚拟环境
离线状态迁移Anaconda虚拟环境 同样是项目需求,需要布署的服务器上的Anaconda安装到了普通账户下 而后续所有的内容都需要通过root账户进行操作,而服务器已经布署,联网比较麻烦 本文提出, ...
- FastAPI 学习之路(五十五)操作Redis
之前我们分享了操作关系型数据库,具体文章, FastAPI 学习之路(三十二)创建数据库 FastAPI 学习之路(三十三)操作数据库 FastAPI 学习之路(三十四)数据库多表操作 这次我们分享的 ...
- 用Python去除PDF水印
今天介绍下用 Python 去除 PDF (图片)的水印.思路很简单,代码也很简洁. 首先来考虑 Python 如何去除图片的水印,然后再将思路复用到 PDF 上面. 这张图片是前几天整理<数据 ...