bzoj5301[CQOI2018]异或序列
题意
已知一个长度为 n 的整数数列 a[1],a[2],…,a[n] ,给定查询参数 l、r ,问在 [l,r] 区间内,有多少连续子
序列满足异或和等于 k 。
也就是说,对于所有的 x,y (l≤x≤y≤r),能够满足a[x]a[x+1]…^a[y]=k的x,y有多少组。
分析
这样的题目首先按照异或运算前缀和,就变成多次查询区间内有多少对数满足异或和为k.
考虑简单的情况.异或和为0的时候,就变成查询区间内有多少对数相同.这是很显然的莫队题目.
那么异或和为k的时候我们也可以考虑莫队.比较简明的思路是用trie树维护区间内所有的数字,加入/删除数字的时候更新答案.
另一种方式是,把所有的前缀和异或上k,组成另外一个数列,那么对于询问的区间在原先的前缀和数列和异或k的前缀和数列上都有一个数集,然后找两个数集的相同的数对(就是找这样的数对:数值相同,但是一个数在这个数集,另一个数在那个数集).
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=100005;
int a[maxn],s1[maxn],s2[maxn];
int cnt1[500000],cnt2[500000],ans;
int SZ=250;
struct query{
int l,r,num,ans;
void read(){
scanf("%d%d",&l,&r);l--;
}
}Q[maxn];
bool cmp1(const query &A,const query &B){
if(A.l/SZ!=B.l/SZ)return A.l<B.l;
return A.r<B.r;
}
void init(int l,int r){
//printf("%d %d\n",l,r);
for(int i=l;i<=r;++i){
//printf("%d ",s1[i]);
cnt1[s1[i]]++;
}//printf("\n");
for(int i=l;i<=r;++i){
cnt2[s2[i]]++;//printf("%d ",s2[i]);
ans+=cnt1[s2[i]];
}//printf("\n");
//printf("%d\n",ans);
}
void move(int l1,int r1,int l2,int r2){
for(int i=l1;i<l2;++i){
ans-=cnt2[s1[i]];ans-=cnt1[s2[i]];
cnt1[s1[i]]--;cnt2[s2[i]]--;
if(s1[i]==s2[i])ans+=1;
}
for(int i=l1-1;i>=l2;--i){
ans+=cnt2[s1[i]];ans+=cnt1[s2[i]];
cnt1[s1[i]]++;cnt2[s2[i]]++;
if(s1[i]==s2[i])ans-=1;
}
for(int i=r1+1;i<=r2;++i){
ans+=cnt2[s1[i]];ans+=cnt1[s2[i]];
cnt1[s1[i]]++;cnt2[s2[i]]++;
if(s1[i]==s2[i])ans-=1;
}
for(int i=r1;i>r2;--i){
ans-=cnt2[s1[i]];ans-=cnt1[s2[i]];
cnt1[s1[i]]--;cnt2[s2[i]]--;
if(s1[i]==s2[i])ans+=1;
}
}
int res[maxn];
int main(){
int n,m,k;scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=n;++i){
scanf("%d",a+i);
}
for(int i=1;i<=n;++i)s1[i]=s1[i-1]^a[i];
for(int i=0;i<=n;++i)s2[i]=s1[i]^k;
for(int i=1;i<=m;++i)Q[i].read();
for(int i=1;i<=m;++i)Q[i].num=i;
sort(Q+1,Q+m+1,cmp1);
init(Q[1].l,Q[1].r);Q[1].ans=ans;
for(int i=2;i<=m;++i){
move(Q[i-1].l,Q[i-1].r,Q[i].l,Q[i].r);
Q[i].ans=ans;
}
if(k==0){
for(int i=1;i<=m;++i)Q[i].ans-=(Q[i].r-Q[i].l+1);
}
for(int i=1;i<=m;++i)Q[i].ans/=2;
for(int i=1;i<=m;++i)res[Q[i].num]=Q[i].ans;
for(int i=1;i<=m;++i)printf("%d\n",res[i]);
return 0;
}
bzoj5301[CQOI2018]异或序列的更多相关文章
- BZOJ5301: [Cqoi2018]异或序列(莫队)
5301: [Cqoi2018]异或序列 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 400 Solved: 291[Submit][Status ...
- [bzoj5301][Cqoi2018]异或序列_莫队
异或序列 bzoj-5301 Cqoi-2018 题目大意:题目链接. 注释:略. 想法: 由于a^a=0这个性质,我们将所有的数变成异或前缀和. 所求就变成了求所有的$l_i\le x<y\l ...
- BZOJ5301:[CQOI2018]异或序列(莫队)
Description 已知一个长度为 n 的整数数列 a[1],a[2],…,a[n] ,给定查询参数 l.r ,问在 [l,r] 区间内,有多少连续子 序列满足异或和等于 k . 也就是说,对于所 ...
- 2018.08.12 bzoj5301: [Cqoi2018]异或序列(前缀和+莫队)
传送门 简单的异或前缀和处理+莫队统计答案. 惊奇的发现无论开不开long long都能跑过... 代码: #include<bits/stdc++.h> #define N 100005 ...
- BZOJ5301 [Cqoi2018]异或序列 【莫队】
题目链接 BZOJ5301 题解 莫队水题 BZOJ400AC纪念 #include<algorithm> #include<iostream> #include<cst ...
- bzoj 5301: [Cqoi2018]异或序列 (莫队算法)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=5301 题面; 5301: [Cqoi2018]异或序列 Time Limit: 10 Sec ...
- 「luogu4462」[CQOI2018] 异或序列
「luogu4462」[CQOI2018]异或序列 一句话题意 输入 \(n\) 个数,给定\(k\),共 \(m\) 组询问,输出第 \(i\) 组询问 \(l_i\) \(r_i\) 中有多少个连 ...
- bzoj 5301 [Cqoi2018]异或序列 莫队
5301: [Cqoi2018]异或序列 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 204 Solved: 155[Submit][Status ...
- 并不对劲的复健训练-bzoj5301:loj2534:p4462 [CQOI2018]异或序列
题目大意 给出一个序列\(a_1,...,a_n\)(\(a,n\leq 10^5\)),一个数\(k\)(\(k\leq 10^5\)),\(m\)(\(m\leq10^5\))次询问,每次询问给\ ...
随机推荐
- HDU1863(Kruskal+并查集水题)
https://cn.vjudge.net/problem/HDU-1863 省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可). ...
- 清北学堂寒假集训DAY1
第一天,上午讲了些基本的技巧和简单算法,主要就是适应这里. 中午跑到食堂吃了顿“饭”(我并没有挖苦233333),然后回宿舍休息休息 因为 迎接我们的是模拟啊啊啊啊啊阿 下午题一发下来,并没有想象中的 ...
- Java java.text.ParseException: Unparseable date
用java将字符串转换成Date类型是,会出现java.text.ParseException: Unparseable date异常. 例如下面的这段代码就会出现上面的异常: public bool ...
- jqgrid 对编辑行填写的内容做格式验证
有时,我们需要在基于jqgrid表格编辑行的单元格做规范验证.jqgrid提供有支持,通过设置字段的editrules属性来约束格式. 约束方式: 1.内置的约束参数 (required: true, ...
- WPF XML序列化保存数据 支持Datagrid 显示/编辑/添加/删除数据
XML序列化保存数据 using System; using System.Collections.Generic; using System.Linq; using System.Text; usi ...
- [Deep-Learning-with-Python]机器学习基础
机器学习类型 机器学习模型评估步骤 深度学习数据准备 特征工程 过拟合 解决机器学习问题的一般性流程 机器学习四分支 二分类.多分类以及回归问题都属于监督学习--目标是学习训练输入和对应标签之间的关系 ...
- [CF1025F]Disjoint Triangles[极角排序+组合计数]
题意 平面上有 \(n\) 个点,选出六个点构成两个三角形,问有多少种构造方式使得两个三角形没有交集. \(n\leq 2000\) 分析 枚举连接两个三角形的两个顶点,同时能够将两个三角形划分在直线 ...
- RxJS v6 学习指南
为什么要使用 RxJS RxJS 是一套处理异步编程的 API,那么我将从异步讲起. 前端编程中的异步有:事件(event).AJAX.动画(animation).定时器(timer). 异步常见的问 ...
- hdu 2036:改革春风吹满地(叉积求凸多边形面积)
改革春风吹满地 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ...
- nodejs安装及npm模块插件安装路径配置
在学习完js后,我们就要进入nodejs的学习,因此就必须配置nodejs和npm的属性了. 我相信,个别人在安装时会遇到这样那样的问题,看着同学都已装好,难免会焦虑起来.于是就开始上网查找解决方案, ...