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\))次询问,每次询问给\ ...
随机推荐
- 03Servlet API
Servlet API Servlet是实现javax.servlet.Servlet接口的对象.大多数Servlet通过从GenericServlet或HttpServlet类进行扩展来实现.Ser ...
- 【转载】Java下利用Jackson进行JSON解析和序列化
参考资料: https://blog.csdn.net/sdut406/article/details/85647982 Java下常见的Json类库有Gson.JSON-lib和Jackson等,J ...
- POJ P2096 Collecting Bugs
思路 分类讨论,不妨先设$DP[i][j]$表示已经发现$i$种子系统中有$n$种$bug$无非只有四种情况 发现的$bug$在旧的系统旧的分类,概率$p1$是$(i/s)*(j/n)$. 发现的$b ...
- MarkDown语法和使用
MarkDown语法: Markdown在线编辑器 MdEditor Markdown 语法整理大集合2017 MarkDown 数学公式 在Markdown中输入数学公式(MathJax) \(\l ...
- Vue2 + Koa2 实现后台管理系统
看了些 koa2 与 Vue2 的资料,模仿着做了一个基本的后台管理系统,包括增.删.改.查与图片上传. 工程目录: 由于 koa2 用到了 async await 语法,所以 node 的版本需要至 ...
- PAT 1085 PAT单位排行
每次 PAT 考试结束后,考试中心都会发布一个考生单位排行榜.本题就请你实现这个功能. 输入格式: 输入第一行给出一个正整数 N(≤10^5),即考生人数.随后 N 行,每行按下列格式给出一个考生的信 ...
- 二、第一个ECharts图表
<!DOCTYPE html> <head> <meta charset="utf-8"> <title>ECharts</t ...
- 常量Constant
常量通常指的是一个固定的值,例如:1.2.3.’a’.’b’.true.false.”helloWorld”等. 在Java语言中,主要是利用关键字final来定义一个常量. 常量一旦被初始化后不能再 ...
- Linux学习总结(21)——CentOS7环境下FTP服务器的安装和配置
1. 安装vsftpd #安装vsftpd yum install -y vsftpd #设置开机启动 systemctl enable vsftpd.service # 重启 service vsf ...
- [luoguP2875] [USACO07FEB]牛的词汇The Cow Lexicon(DP)
传送门 f[i] 表示前 i 个字符去掉多少个 的最优解 直接暴力DP ——代码 #include <cstdio> #include <cstring> #include & ...