\(\\\)

Description


给出一个长为 \(n\) 的数列 \(A\) 和 \(k\),多次询问:

对于一个区间 \([L_i,R_i]\),问区间内有多少个不为空的子段异或和为 \(k\) 。

  • \(n,m,k,A_i\le 10^5\)

\(\\\)

Solution


注意到一件有趣的事,就是每次询问的 \(k\) 相同。

因为 \(a\oplus a=0\),所以子段异或问题可以看作前缀异或和的异或,即

\[a[i]\oplus a[i+1]\oplus...\oplus a[j]=sum[i-1]\oplus sum[j]
\]

其中 \(sum[i]=a[1]\oplus a[2]\oplus...\oplus a[i]\) 。

那么问题转化为,存在对少对 \(i,j\in[L_i-1,R_i],i!=j\) ,满足

\[sum[i]\oplus sum[j]=k
\]

注意区间问题,因为区间做差的原理是减掉 \(l-1\) 。

然后可以注意到,一个值 \(x\) 若想要构成 \(k\) ,其对应的另一个值是固定的。

也就是说,我们的组合方案是确定的。

当新加入一个可选值 \(x\) ,我们的方案数就会 \(+cnt[x^k]\) ,其中 \(cnt[i]\) 表示当前含有可选值 \(i\) 的个数。

可以证明,这种计数方式不会算重,因为每个数字加入时只会计算当前已经有对应的值。

当去掉一个值的时候,方案数 \(-cnt[x^k]\) 即可。

\(\\\)

还有一个问题,就是关于 \(k=0\) 的情况。

此时每个值显然不能计算上自己和自己异或的贡献。

删除时当然也要注意不能多减掉自己异或自己的情况。

只需在 adddel 的时候交换一下操作顺序即可,具体看代码。

\(\\\)

Code


突然失智......Debug 2h 竟只是因为 \(l\) 没有减 \(1\) ......

还要注意,刚开始 \(0\) 号位置也有一个贡献。

#include<cmath>
#include<cstdio>
#include<cctype>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 100010
#define R register
#define gc getchar
using namespace std;
typedef long long ll; inline ll rd(){
ll x=0; bool f=0; char c=gc();
while(!isdigit(c)){if(c=='-')f=1;c=gc();}
while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=gc();}
return f?-x:x;
} ll n,m,k,ans,bl[N],cnt[1<<18],s[N],res[N]; struct Q{ll l,r,id;}q[N]; inline bool cmp1(Q x,Q y){
return bl[x.l]==bl[y.l]?x.r<y.r:bl[x.l]<bl[y.l];
} inline bool cmp2(Q x,Q y){return x.id<y.id;} inline void del(int p){
--cnt[s[p]];
ans-=cnt[k^s[p]];
} inline void add(int p){
ans+=cnt[k^s[p]];
++cnt[s[p]];
} int main(){
n=rd(); m=rd(); k=rd();
ll t=sqrt(n);
for(R ll i=1;i<=n;++i){
s[i]=s[i-1]^rd();
bl[i]=i/t+1;
}
for(R ll i=1;i<=m;++i){
q[i].l=rd()-1; q[i].r=rd(); q[i].id=i;
}
sort(q+1,q+1+m,cmp1);
ll nowl=0,nowr=0;
cnt[0]=1;
for(R ll i=1;i<=m;++i){
while(nowl>q[i].l){--nowl;add(nowl);}
while(nowl<q[i].l){del(nowl);++nowl;}
while(nowr<q[i].r){++nowr;add(nowr);}
while(nowr>q[i].r){del(nowr);--nowr;}
res[q[i].id]=ans;
}
for(R ll i=1;i<=m;++i) printf("%lld\n",res[i]);
return 0;
}

[ CQOI 2018 ] 异或序列的更多相关文章

  1. [CQOI 2018]异或序列&[Codeforces 617E]XOR and Favorite Number

    Description 题库链接1 题库链接2 已知一个长度为 \(n\) 的整数数列 \(a_1,a_2,\cdots,a_n\) ,给定查询参数 \(l,r\) ,问在 \([l,r]\) 区间内 ...

  2. bzoj 5301: [Cqoi2018]异或序列 (莫队算法)

    链接:https://www.lydsy.com/JudgeOnline/problem.php?id=5301 题面; 5301: [Cqoi2018]异或序列 Time Limit: 10 Sec ...

  3. 「luogu4462」[CQOI2018] 异或序列

    「luogu4462」[CQOI2018]异或序列 一句话题意 输入 \(n\) 个数,给定\(k\),共 \(m\) 组询问,输出第 \(i\) 组询问 \(l_i\) \(r_i\) 中有多少个连 ...

  4. P3917 异或序列

    P3917 异或序列暴力前缀异或枚举每一个区间,再求和,60分.正解:按每一位来做对于区间[l,r],如果它对答案有贡献,区间中1的个数一定是奇数,可以按每一位取(1<<i)的前缀和,q[ ...

  5. bzoj 5301 [Cqoi2018]异或序列 莫队

    5301: [Cqoi2018]异或序列 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 204  Solved: 155[Submit][Status ...

  6. BZOJ5301: [Cqoi2018]异或序列(莫队)

    5301: [Cqoi2018]异或序列 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 400  Solved: 291[Submit][Status ...

  7. Loj 2534 异或序列

    Loj 2534 异或序列 考虑莫队离线处理.每加一个数,直接询问 \(a[x]\oplus k\) 的前/后缀数目即可,减同理. 利用异或的优秀性质,可以维护异或前缀和,容易做到每次 \(O(1)\ ...

  8. 【BZOJ5301】【CQOI2018】异或序列(莫队)

    [BZOJ5301][CQOI2018]异或序列(莫队) 题面 BZOJ 洛谷 Description 已知一个长度为 n 的整数数列 a[1],a[2],-,a[n] ,给定查询参数 l.r ,问在 ...

  9. [bzoj5301][Cqoi2018]异或序列_莫队

    异或序列 bzoj-5301 Cqoi-2018 题目大意:题目链接. 注释:略. 想法: 由于a^a=0这个性质,我们将所有的数变成异或前缀和. 所求就变成了求所有的$l_i\le x<y\l ...

随机推荐

  1. 附录: mysql show processlist中的State的意义

    附录: mysql show processlist中的State的意义 Checking table 正在检查数据表(这是自动的). Closing tables 正在将表中修改的数据刷新到磁盘中, ...

  2. [Android6.0][RK3399] 修改默认按键 KEY-PAD 的功能【转】

    本文转载自:http://m.blog.csdn.net/dearsq/article/details/70175637 Platform: RK3399 OS: Android 6.0 Kernel ...

  3. Codeforces Round #106 (Div. 2) D. Coloring Brackets —— 区间DP

    题目链接:https://vjudge.net/problem/CodeForces-149D D. Coloring Brackets time limit per test 2 seconds m ...

  4. Do not throw System.Exception, System.SystemException, System.NullReferenceException, or System.IndexOutOfRangeException intentionally from your own source code

    sonarqube的扫描结果提示 https://docs.microsoft.com/en-us/dotnet/csharp/programming-guide/exceptions/creatin ...

  5. "standard,singleTop,singleTask,singleInstance"-Android启动模式

    安卓有4种启动模式,下面我们就进行详细的讲解 用栈的思维去理解,就能理解这些启动模式的本质了 先设置两个页面: A(为测试对象),B两个页面,两个页面都有跳至对方的按钮 一.标准模式(standard ...

  6. 廖雪峰python3练习题二

    字符串和编码 题目: 答案: #!/usr/bin/env python3 #-*- coding:utf-8 -*- s1 = 72 s2 = 85 print('小明的成绩提高了%.1f%%个百分 ...

  7. 量子纠缠2——CHSH不等式

    问题 有Alice和Bob两个人,随机给他们两个数x和y(0或1),然后A和B根据他们得到数(x和y)给两个个数a和b(0或1). 规则如下: 如果输入的x和y都是1,那么,Alice和Bob给出不一 ...

  8. 在Emacs下用C/C++编程(转载)

    转自:http://www.caole.net/diary/emacs_write_cpp.html Table of Contents 版权说明和参考文献 参考文献: 版权说明: 序 基本流程 基本 ...

  9. hdoj5024【BFS/暴力】

    题意: 在可以行走的区域内,只能转一次90度的弯,问你最长这条路可以多长. 思路: 我们可以看到 /* 123 8 4 765 */ 转90度的路径会是横竖,也就是1-3-5-7; 还有斜的:2-4- ...

  10. 求导四则运算以及三角函数求导 Derivative formulas

    对特定函数的求导. 1:sin(x) 对其进行求斜率.带入公式得:[ sin(x+Δx)- sin(x)]/Δx  = [ sinx*cosΔx + cosx*sinΔx -sin x ]/ Δx = ...