「CF242E」XOR on Segment 解题报告
题面
长度为\(n\)的数列,现有两种操作:
1、区间异或操作
2、区间求和操作
对于每个查询,输出答案
思路:
线段树+二进制拆位
线段树区间修改一般使用的都是懒标记的方法,但是对于异或,懒标记的方法显然是行不通的,于是就考虑二进制拆位
主要的思路就是将一个数,拆成若干个二进制位,然后对于异或操作,就转换成了每一位上的异或操作
分类讨论一下:
1、当\(x\)的第\(i\)位为\(1\)时,\(1\ xor\ 0=1\),\(1\ xor\ 1=0\)
也就是看成区间取反操作
2、当\(x\)的第\(i\)位为\(0\)时,\(0\ xor\ 0=0\),\(0\ xor\ 1=1\)
也就是说操作前后没有变化,所以就不执行修改操作
Code:
#include<bits/stdc++.h>
#define ll long long
#define N 100010
using namespace std;
int n,a[N],res,L,R,T,x;
int f[N<<2][25],tag[N<<2][25];//1e6<2^20
ll b[25],ans;//别忘记long long
int read(){ int s=0;char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)){s=(s<<1)+(s<<3)+c-'0';c=getchar();}
return s;
}
void built(int k,int l,int r)
{
if(l>r) return;
if(l==r)
{
res=a[l];
for(int i=0;i<21;i++)//拆位
if((res>>i)&1) f[k][i]=1;
return;
}
int mid=(l+r)>>1,cur=k<<1;
built(cur,l,mid);
built(cur|1,mid+1,r);
for(int i=0;i<21;i++)
f[k][i]=f[cur][i]+f[cur|1][i];
return;
}
void push(int k,int l,int r,int p)//p表示第几位
{
f[k][p]=(r-l+1)-f[k][p];//区间取反
if(l!=r)
{
int cur=k<<1;
tag[cur][p]^=1;
tag[cur|1][p]^=1;
}
tag[k][p]=0;
}
void Modify(int k,int l,int r,int p)//p同上
{
if(tag[k][p]) push(k,l,r,p);
if(r<L||R<l) return;
if(L<=l&&r<=R)
{
push(k,l,r,p);
return;
}
int mid=(l+r)>>1,cur=k<<1;
Modify(cur,l,mid,p);
Modify(cur|1,mid+1,r,p);
f[k][p]=f[cur][p]+f[cur|1][p];
}
void Query(int k,int l,int r)//查询,所有位的懒标记都要下放
{
for(int i=0;i<21;i++)
if(tag[k][i]) push(k,l,r,i);
if(r<L||R<l) return;
if(L<=l&&r<=R)
{
for(int i=0;i<21;i++) ans+=f[k][i]*b[i];
return;
}
int mid=(l+r)>>1,cur=k<<1;
Query(cur,l,mid);
Query(cur|1,mid+1,r);
}
int main()
{
int i,j;b[0]=1;
for(i=1;i<=21;i++) b[i]=b[i-1]<<1;//初不初始化都可以,就是上面b[i]要变成1<<i
n=read();
for(i=1;i<=n;i++) a[i]=read();
built(1,1,n);
T=read();
while(T--)
{
if(read()==1)
{
L=read();R=read();ans=0;
Query(1,1,n);
printf("%lld\n",ans);
}
else
{
L=read();R=read();x=read();
for(i=0;i<21;i++)//判断x的第i位是不是1,并进行修改
if((x>>i)&1) Modify(1,1,n,i);
}
}
return 0;
}
「CF242E」XOR on Segment 解题报告的更多相关文章
- 洛谷 P4714 「数学」约数个数和 解题报告
P4714 「数学」约数个数和 题意(假):每个数向自己的约数连边,给出\(n,k(\le 10^{18})\),询问\(n\)的约数形成的图中以\(n\)为起点长为\(k\)的链有多少条(注意每个点 ...
- 「NOI2013」树的计数 解题报告
「NOI2013」树的计数 这什么神题 考虑对bfs重新编号为1,2,3...n,然后重新搞一下dfs序 设dfs序为\(dfn_i\),dfs序第\(i\)位对应的节点为\(pos_i\) 一个暴力 ...
- 「NOI2016」优秀的拆分 解题报告
「NOI2016」优秀的拆分 这不是个SAM题,只是个LCP题目 95分的Hash很简单,枚举每个点为开头和末尾的AA串个数,然后乘一下之类的. 考虑怎么快速求"每个点为开头和末尾的AA串个 ...
- 「NOI2016」循环之美 解题报告
「NOI2016」循环之美 对于小数\(\frac{a}{b}\),如果它在\(k\)进制下被统计,需要满足要求并且不重复. 不重复我们确保这个分数是最简分数即\((a,b)=1\) 满足要求需要满足 ...
- 「FJOI2018」领导集团问题 解题报告
「FJOI2018」领导集团问题 题意:给你一颗\(n\)个点的带点权有根树,选择一个点集\(S\),使得点集中所有祖先的点权$\le \(子孙的点权,最大化\)|S|$(出题人语死早...) 一个显 ...
- 「SP25784」BUBBLESORT - Bubble Sort 解题报告
SP25784 BUBBLESORT - Bubble Sort 题目描述 One of the simplest sorting algorithms, the Bubble Sort, can b ...
- 「SP122」STEVE - Voracious Steve 解题报告
SP122 STEVE - Voracious Steve 题意翻译 Problem Steve和他的一个朋友在玩游戏,游戏开始前,盒子里有 n个甜甜圈,两个人轮流从盒子里抓甜甜圈,每次至少抓 1个, ...
- 「Luogu」[JSOI2007]字符加密 解题报告
题面 思路: 作为一个后缀数组的初学者,当然首先想到的是后缀数组 把\(s\)这个串首尾相接,扩展为原来的两倍,就能按后缀数组的方法处理 证明: 神仙一眼就看出这是后缀的裸题,我这个蒟蒻想了半天想不出 ...
- 「P5004」专心OI - 跳房子 解题报告
题面 把\(N\)个无色格子排成一行,选若干个格子染成黑色,要求每个黑色格子之间至少间隔\(M\)个格子,求方案数 思路: 矩阵加速 根据题面,这一题似乎可以用递推 设第\(i\)个格子的编号为\(i ...
随机推荐
- 【hiho一下 第147周】小Hi的烦恼
[题目链接]:http://hihocoder.com/contest/hiho147/problem/1 [题意] [题解] bitset的应用; 设better[j][i]表示第j个科目排名为1. ...
- [***]HZOJ 哪一天她能重回我身边
%%%神仙题. 居然是图论,我还一直以为是二分图或者啥数据结构. 直接说正解了,将数看作节点,牌看做边,从牌的正面的数想反面连边权为1的边,反面向正面连边权为0的边(注意用到成对存储的技巧,之后会非常 ...
- Project Euler Problem 18-Maximum path sum I & 67-Maximum path sum II
基础的动态规划...数塔取数问题. 状态转移方程: dp[i][j] = num[i][j] + max(dp[i+1][j],dp[i+1][j+1]);
- hdu 1289 Hat’s IEEE
Problem - 1289 好题.其实就是模拟IEEE754的格式,不过要注意的是,这里用的32位是float,用double就不对了. 代码如下: #include <cstdio> ...
- js数组冒泡排序
文章地址 https://www.cnblogs.com/sandraryan/ js数组的冒泡排序是最经典的一种排序方式(我以为). 冒泡排序是吧一组数组的元素两两比较,交换位置,通过多轮比较,实现 ...
- error LNK2001: unresolved external symbol __imp___rt_sdiv
这个问题搞了我 5 天(包括双休日), 我一定要记录下来. 问题描述 用 Visual Studio 2008 编译 WinCE 7 平台的应用程序,编译没问题,链接时出现了一堆 Link error ...
- 软件自动化测试 selenium IDE + Firebug + python脚本
按顺序步骤来 一.安装软件 1.1.1 webDriver(就是selenium IDE) 解析:本来这两个东西就合成一个了,但是更新到后来,安装的时候又独立安装的. 安装 Python ...
- 我来教你用AWS IoT.Part1--配置和接入
AWS的IOT服务在中国区才开放.由于工作原因需要简单试用评估.写一下自己简单试用的流程,供其他人参考. 直接贴流程 1.先注册一个类型(这里“类型”相对于编程,可以理解为父类,里面可以添加一些可继承 ...
- java.lang.ClassCastException: com.sun.proxy.$Proxy6 cannot be cast to com.etc.service.serviceImpl.BankServiceImpl
错误原因: java.lang.ClassCastException: com.sun.proxy.$Proxy6 cannot be cast to com.etc.service.serviceI ...
- python基础八之文件操作
python的文件操作 1,打开文件 编码方式要和文件的编码方式相同! #open('路径','打开方式','指定编码方式') f = open(r'E:\pycharm\学习\day8\test', ...