codechef Chef And Easy Xor Queries
做法:我们考虑前缀异或和,修改操作就变成了区间[i,n]都异或x
查询操作就变成了:区间[1,x]中有几个k
显然的分块,每个块打一个tag标记表示这个块中所有的元素都异或了tag[x]
然后处理出这个块中每种数的个数
注意查询的时候零散的块要下放标记
代码:
#include<bits/stdc++.h>
#define N 100005
#define M 334
using namespace std;
int cnt[M][N*14],sum[N],tag[M],ll[M],rr[M],a[N];
int n,Q,opt,x,y,block,num;
inline int gt(int x){return (x-1)/block+1;}
inline void pushdown(int x){
if (!tag[x]) return;
for (int i=ll[x];i<=rr[x];i++){
cnt[x][sum[i]]--;
sum[i]^=tag[x];
cnt[x][sum[i]]++;
}
tag[x]=0;
}
inline void query(int x,int y,int k){
//printf("%d %d\n",gt(x),gt(y));
int ans=0;
pushdown(gt(x));pushdown(gt(y));
if (gt(x)+1>=gt(y)){
for (int i=x;i<=y;i++) if (sum[i]==k) ans++;
}
else {
for (int i=x;i<=rr[gt(x)];i++) if (sum[i]==k) ans++;
for (int i=ll[gt(y)];i<=y;i++) if (sum[i]==k) ans++;
for (int j=gt(x)+1;j<gt(y);j++) ans+=cnt[j][k^tag[j]];
}
printf("%d\n",ans);
}
inline void change(int x,int y,int z){
int tmp=z;z=z^a[x];a[x]=tmp;
if (gt(x)+1>=gt(y)){
for (int i=x;i<=y;i++){
cnt[gt(i)][sum[i]]--;
sum[i]^=z;
cnt[gt(i)][sum[i]]++;
}
}
else {
for (int i=x;i<=rr[gt(x)];i++){
cnt[gt(i)][sum[i]]--;
sum[i]^=z;
cnt[gt(i)][sum[i]]++;
}
for (int i=ll[gt(y)];i<=y;i++){
cnt[gt(i)][sum[i]]--;
sum[i]^=z;
cnt[gt(i)][sum[i]]++;
}
for (int j=gt(x)+1;j<gt(y);j++) tag[j]^=z;
}
//for (int i=1;i<=n;i++) printf("%d %d\n",sum[i],tag[i]);
}
int main(){
scanf("%d%d",&n,&Q);
for (int i=1;i<=n;i++) scanf("%d",&a[i]),sum[i]=sum[i-1]^a[i];
block=(int)sqrt(n);num=n/block;if (n%block) num++;
for (int i=1;i<=num;i++) ll[i]=(i-1)*block+1,rr[i]=i*block;rr[num]=n;
//for (int i=1;i<=num;i++) printf("%d %d\n",ll[i],rr[i]);
for (int i=1;i<=num;i++)
for (int j=ll[i];j<=rr[i];j++) cnt[i][sum[j]]++;
while (Q--){
scanf("%d%d%d",&opt,&x,&y);
if (opt==2) query(1,x,y);
else change(x,n,y);
}
return 0;
}
- #include<bits/stdc++.h>
- #define N 100005
- #define M 334
- using namespace std;
- int cnt[M][N*14],sum[N],tag[M],ll[M],rr[M],a[N];
- int n,Q,opt,x,y,block,num;
- inline int gt(int x){return (x-1)/block+1;}
- inline void pushdown(int x){
- if (!tag[x]) return;
- for (int i=ll[x];i<=rr[x];i++){
- cnt[x][sum[i]]--;
- sum[i]^=tag[x];
- cnt[x][sum[i]]++;
- }
- tag[x]=0;
- }
- inline void query(int x,int y,int k){
- //printf("%d %d\n",gt(x),gt(y));
- int ans=0;
- pushdown(gt(x));pushdown(gt(y));
- if (gt(x)+1>=gt(y)){
- for (int i=x;i<=y;i++) if (sum[i]==k) ans++;
- }
- else {
- for (int i=x;i<=rr[gt(x)];i++) if (sum[i]==k) ans++;
- for (int i=ll[gt(y)];i<=y;i++) if (sum[i]==k) ans++;
- for (int j=gt(x)+1;j<gt(y);j++) ans+=cnt[j][k^tag[j]];
- }
- printf("%d\n",ans);
- }
- inline void change(int x,int y,int z){//[x,y]����^z
- int tmp=z;z=z^a[x];a[x]=tmp;
- if (gt(x)+1>=gt(y)){
- for (int i=x;i<=y;i++){
- cnt[gt(i)][sum[i]]--;
- sum[i]^=z;
- cnt[gt(i)][sum[i]]++;
- }
- }
- else {
- for (int i=x;i<=rr[gt(x)];i++){
- cnt[gt(i)][sum[i]]--;
- sum[i]^=z;
- cnt[gt(i)][sum[i]]++;
- }
- for (int i=ll[gt(y)];i<=y;i++){
- cnt[gt(i)][sum[i]]--;
- sum[i]^=z;
- cnt[gt(i)][sum[i]]++;
- }
- for (int j=gt(x)+1;j<gt(y);j++) tag[j]^=z;
- }
- //for (int i=1;i<=n;i++) printf("%d %d\n",sum[i],tag[i]);
- }
- int main(){
- scanf("%d%d",&n,&Q);
- for (int i=1;i<=n;i++) scanf("%d",&a[i]),sum[i]=sum[i-1]^a[i];
- block=(int)sqrt(n);num=n/block;if (n%block) num++;
- for (int i=1;i<=num;i++) ll[i]=(i-1)*block+1,rr[i]=i*block;rr[num]=n;
- //for (int i=1;i<=num;i++) printf("%d %d\n",ll[i],rr[i]);
- for (int i=1;i<=num;i++)
- for (int j=ll[i];j<=rr[i];j++) cnt[i][sum[j]]++;
- while (Q--){
- scanf("%d%d%d",&opt,&x,&y);
- if (opt==2) query(1,x,y);
- else change(x,n,y);
- }
- return 0;
- }
codechef Chef And Easy Xor Queries的更多相关文章
- CF&&CC百套计划2 CodeChef December Challenge 2017 Chef And Easy Xor Queries
https://www.codechef.com/DEC17/problems/CHEFEXQ 题意: 位置i的数改为k 询问区间[1,i]内有多少个前缀的异或和为k 分块 sum[i][j] 表示第 ...
- [CC-XXOR]Chef and Easy Problem
[CC-XXOR]Chef and Easy Problem 题目大意: 给你一个长度为\(n(n\le10^5)\)的序列\(A(A_i<2^{31})\).\(m(m\le10^5)\)次询 ...
- Codeforces Round #440 (Div. 2, based on Technocup 2018 Elimination Round 2) D. Something with XOR Queries
地址:http://codeforces.com/contest/872/problem/D 题目: D. Something with XOR Queries time limit per test ...
- XOR Queries(莫队+trie)
题目链接: XOR Queries 给出一个长度为nn的数组CC,回答mm个形式为(L, R, A, B)(L,R,A,B)的询问,含义为存在多少个不同的数组下标k \in [L, R]k∈[L,R] ...
- XOR Queries
XOR Queries 时间限制: 1000ms 内存限制: 256M 描述 给出一个长度为n的数组C,回答m个形式为(L,R,A,B)的询问,含义为存在多少个不同的数组下标k∈[L,R]满足C[ ...
- CodeChef:Chef and Problems(分块)
CodeChef:Chef and Problems 题目大意 有一个长度为n的序列$a_1,a_2,……,a_n$,每次给出一个区间[l,r],求在区间内两个相等的数的最远距离($max(j-i,满 ...
- CODECHEF Chef and Churus 解题报告
[CODECHEF]Chef and Churus Description 有一个长度为\(n\)的数组\(A\),有\(n\)个函数,第\(i\)个函数的值为\(\sum_{j=l_i}^{r_i} ...
- codechef Chef and The Right Triangles 题解
Chef and The Right Triangles The Chef is given a list of N triangles. Each triangle is identfied by ...
- 【CodeChef PREFIXOR】Prefix XOR
https://odzkskevi.qnssl.com/f0fbdb108ec813b1294f8f714805963b?v=1502083692 网上搜到的题解: http://blog.csdn. ...
随机推荐
- Java中数组的扩容
在写程序的过程中,我们常常会碰见数组空间不够用的情况,比如我已经初始化了一个数组int []a = {1,2,3,4,5,6,7,8,9,10} ;这时,我想往数组下标3的位置插入一个元素,该怎么做? ...
- 【一天一道LeetCode】#99. Recover Binary Search Tree
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Two ele ...
- 【shell脚本练习】判断用户存在和用户类型
题目 写一个脚本 1. 传递一个参数给脚本,此参数为用户名: 2. 如果用户存在,则执行如下任务 * 如果用户的id号小于500,显示其为管理员或系统用户: * 否则,显示其为普通用户: 3. 如果用 ...
- Opencv学习笔记------Harris角点检测
image算法测试iteratoralgorithmfeatures 原创文章,转载请注明出处:http://blog.csdn.net/crzy_sparrow/article/details/73 ...
- mysql进阶(十七)Cannot Connect to Database Server
Cannot Connect to Database Server 缘由 由于不同的项目中使用的数据库用户名与密码出现了不一致的情况,在其中之前较早一个项目执行过程中出现"The user ...
- iOS中UITableView分割线左侧顶齐
iOS 7开始UITableView的分割线不在从左侧边界开始了,而是默认空出了一段距离. 如果想要使用默认的分割线而且还要从左侧边界开始的话,有几种解决方式: 1.在tableView的代理方法中设 ...
- DataLoad命令
Dataload常用命令 Dataload命令符 说明 Tab 或\{tab} 键盘Tab键,下一个单元 *UP 或\{UP} 键盘上 *DN 或\{DOWN} 键盘下 *LT 或\{LEFT ...
- 自定义view入门
如何自定义控件主要分为以下几个步骤: 1.自定义属性的声明与获取 (1)分析需要的自定义属性 (2)在res/values/attrs.xml定义声明,如 <resources> < ...
- dex分包方案
当一个app的功能越来越复杂,代码量越来越多,也许有一天便会突然遇到下列现象: 1. 生成的apk在2.3以前的机器无法安装,提示INSTALL_FAILED_DEXOPT 2. 方法数量过多,编译时 ...
- PS 滤镜—— 径向模糊
这里给出灰度图像的模糊算法,彩色图像只要分别对三个通道做模糊即可. %%% radiation blur %%% clc; clear all; close all; I=imread('4.j ...