LuoguP4462 [CQOI2018]异或序列
https://zybuluo.com/ysner/note/1124952
题面
给你一个大小为\(n\)的序列,然后给你一个数字\(k\),再给出\(m\)组询问,询问给出一个区间,问这个区间里面有多少个区间的异或结果为\(k\).
- \(n,m\leq10^5\)
解析
莫队裸题。
于是我交了份傻逼代码。(于是RE成30分)
struct line
{
int l,r,pos;
bool operator < (const line &o) const {return (l/len)==(o.l/len)?(r<o.r):(l<o.l);}
}a[N];
il void add(re int x,re int f,re int ysn)
{
re int tot=0;
if(!f)
fp(i,x,R)
{
tot^=p[i];
if(tot==k) now+=ysn;
}
else
fq(i,x,L)
{
tot^=p[i];
if(tot==k) now+=ysn;
}
}
int main()
{
n=gi();m=gi();k=gi();len=sqrt(n);
fp(i,1,n) p[i]=gi();
fp(i,1,m) a[i].l=gi(),a[i].r=gi(),a[i].pos=i;
sort(a+1,a+1+m);
L=1,R=0;
fp(i,1,m)
{
re int l=a[i].l,r=a[i].r;
while(L>l) add(--L,0,1);
while(R<r) add(++R,1,1);
while(L<l) add(L++,0,-1);
while(R>r) add(R--,1,-1);
ans[a[i].pos]=now;
}
fp(i,1,m) printf("%d\n",ans[i]);
return 0;
}
喂喂喂,极限复杂度是\(O(n^2)\)呢。。。
于是用下脑子,发现可以存一下当前统计答案的区间中每种值的数目,每加上或减去\(x\)时,相应统计\(num[k\bigoplus x]\)的贡献即可。
// luogu-judger-enable-o2
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#define re register
#define il inline
#define ll long long
#define fp(i,a,b) for(re int i=a;i<=b;i++)
#define fq(i,a,b) for(re int i=a;i>=b;i--)
using namespace std;
const int N=5e5+100;
int n,m,k,p[N],len,ans[N],now,L,R,num[N];
struct line
{
int l,r,pos;
bool operator < (const line &o) const {return (l/len)==(o.l/len)?(r<o.r):(l<o.l);}
}a[N];
il int gi()
{
re char ch=getchar();
re int x=0,t=1;
while(ch!='-'&&(ch<'0'||ch>'9')) ch=getchar();
if(ch=='-') t=-1,ch=getchar();
while(ch>='0'&&ch<='9') x=x*10+ch-48,ch=getchar();
return x*t;
}
il void add(re int x){now+=num[k^p[x]];++num[p[x]];}
il void del(re int x){--num[p[x]];now-=num[k^p[x]];}
int main()
{
n=gi();m=gi();k=gi();len=sqrt(n);
fp(i,1,n) p[i]=gi()^p[i-1];
fp(i,1,m) a[i].l=gi()-1,a[i].r=gi(),a[i].pos=i;
sort(a+1,a+1+m);
L=0,R=-1;
fp(i,1,m)
{
re int l=a[i].l,r=a[i].r;
while(L>l) add(--L);
while(R<r) add(++R);
while(L<l) del(L++);
while(R>r) del(R--);
ans[a[i].pos]=now;
}
fp(i,1,m) printf("%d\n",ans[i]);
return 0;
}
LuoguP4462 [CQOI2018]异或序列的更多相关文章
- 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: [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 ...
- BZOJ_5301_[Cqoi2018]异或序列&&CF617E_莫队
Description 已知一个长度为 n 的整数数列 a[1],a[2],…,a[n] ,给定查询参数 l.r ,问在 [l,r] 区间内,有多少连续子 序列满足异或和等于 k . 也就是说,对于所 ...
- bzoj5301[CQOI2018]异或序列
题意 已知一个长度为 n 的整数数列 a[1],a[2],-,a[n] ,给定查询参数 l.r ,问在 [l,r] 区间内,有多少连续子 序列满足异或和等于 k . 也就是说,对于所有的 x,y (l ...
- BZOJ5301:[CQOI2018]异或序列(莫队)
Description 已知一个长度为 n 的整数数列 a[1],a[2],…,a[n] ,给定查询参数 l.r ,问在 [l,r] 区间内,有多少连续子 序列满足异或和等于 k . 也就是说,对于所 ...
- 并不对劲的复健训练-bzoj5301:loj2534:p4462 [CQOI2018]异或序列
题目大意 给出一个序列\(a_1,...,a_n\)(\(a,n\leq 10^5\)),一个数\(k\)(\(k\leq 10^5\)),\(m\)(\(m\leq10^5\))次询问,每次询问给\ ...
随机推荐
- js数组的处理
//重写Array中的indexOf方法,获取数组中指定值的元素的索引 Array.prototype.indexOf = function (val) { for (var i = 0; i < ...
- Go:值类型、引用类型
值类型,变量存的就是值本身: in系列t.float系列.bool.string.数组和struct 引用类型,变量存的是一个地址,这是地址存的才是值本身: 指针.slice.map.chan.int ...
- JSP页面中的动作标识
JSP页面中的动作标识 制作人:全心全意 包含文件标识<jsp:include> 此标识和include指令类似,用于向当前页面中包含其它的文件,且包含的文件可以是动态文件,也可以是静态文 ...
- 06 Python流程控制
目录: 12) if语句 13) 三目运算 14) while语句 15) break与continue关键字 16) while…else语句 12,if语句 Note: 在一个if语 ...
- PAT 1138 Postorder Traversal
Suppose that all the keys in a binary tree are distinct positive integers. Given the preorder and in ...
- RequestMapping_PathVariable注解
[@PathVariable 映射URL绑定的占位符] 1.带占位符的URL是Spring 3.0 新增的功能,该功能在Spring MVC向 REST 目标挺进发展过程中具有里程碑的意义. 2.通过 ...
- 九度oj 题目1045:百鸡问题
题目1045:百鸡问题 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:10418 解决:4559 题目描述: 用小于等于n元去买100只鸡,大鸡5元/只,小鸡3元/只,还有1/3元每只的一 ...
- Codeforces Round #246 (Div. 2) D. Prefixes and Suffixes
D. Prefixes and Suffixes You have a string s = s ...
- noip模拟赛 寻宝之后
题目背景 还记得NOIP2011的寻宝吗?6年之后,小明带着他的妹子小芳,再次走上了寻宝的道路. 然而这次他们寻宝回来之后,小明被困在了一个迷宫中. 题目描述 迷宫是一个n*m的字符矩阵. 小明在这个 ...
- [NOIP2004]FBI树
题目描述 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全“1”串称为I串,既含“0”又含“1”的串则称为F串. FBI树是一种二叉树,它的结点类型也包括F结点,B结点和I结点三 ...