题面

长度为\(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 解题报告的更多相关文章

  1. 洛谷 P4714 「数学」约数个数和 解题报告

    P4714 「数学」约数个数和 题意(假):每个数向自己的约数连边,给出\(n,k(\le 10^{18})\),询问\(n\)的约数形成的图中以\(n\)为起点长为\(k\)的链有多少条(注意每个点 ...

  2. 「NOI2013」树的计数 解题报告

    「NOI2013」树的计数 这什么神题 考虑对bfs重新编号为1,2,3...n,然后重新搞一下dfs序 设dfs序为\(dfn_i\),dfs序第\(i\)位对应的节点为\(pos_i\) 一个暴力 ...

  3. 「NOI2016」优秀的拆分 解题报告

    「NOI2016」优秀的拆分 这不是个SAM题,只是个LCP题目 95分的Hash很简单,枚举每个点为开头和末尾的AA串个数,然后乘一下之类的. 考虑怎么快速求"每个点为开头和末尾的AA串个 ...

  4. 「NOI2016」循环之美 解题报告

    「NOI2016」循环之美 对于小数\(\frac{a}{b}\),如果它在\(k\)进制下被统计,需要满足要求并且不重复. 不重复我们确保这个分数是最简分数即\((a,b)=1\) 满足要求需要满足 ...

  5. 「FJOI2018」领导集团问题 解题报告

    「FJOI2018」领导集团问题 题意:给你一颗\(n\)个点的带点权有根树,选择一个点集\(S\),使得点集中所有祖先的点权$\le \(子孙的点权,最大化\)|S|$(出题人语死早...) 一个显 ...

  6. 「SP25784」BUBBLESORT - Bubble Sort 解题报告

    SP25784 BUBBLESORT - Bubble Sort 题目描述 One of the simplest sorting algorithms, the Bubble Sort, can b ...

  7. 「SP122」STEVE - Voracious Steve 解题报告

    SP122 STEVE - Voracious Steve 题意翻译 Problem Steve和他的一个朋友在玩游戏,游戏开始前,盒子里有 n个甜甜圈,两个人轮流从盒子里抓甜甜圈,每次至少抓 1个, ...

  8. 「Luogu」[JSOI2007]字符加密 解题报告

    题面 思路: 作为一个后缀数组的初学者,当然首先想到的是后缀数组 把\(s\)这个串首尾相接,扩展为原来的两倍,就能按后缀数组的方法处理 证明: 神仙一眼就看出这是后缀的裸题,我这个蒟蒻想了半天想不出 ...

  9. 「P5004」专心OI - 跳房子 解题报告

    题面 把\(N\)个无色格子排成一行,选若干个格子染成黑色,要求每个黑色格子之间至少间隔\(M\)个格子,求方案数 思路: 矩阵加速 根据题面,这一题似乎可以用递推 设第\(i\)个格子的编号为\(i ...

随机推荐

  1. java+内存分配及变量存储位置的区别

    Java内存分配与管理是Java的核心技术之一,之前我们曾介绍过Java的内存管理与内存泄露以及Java垃圾回收方面的知识,今天我们再次深入Java核心,详细介绍一下Java在内存分配方面的知识.一般 ...

  2. hdu 1434 幸福列车 (Leftist Tree)

    Problem - 1434 网上题解是普通的堆合并,都是用优先队列直接做的.可是正解的堆合并应该是用左偏堆或者斐波那契堆的吧,不然O(X * N ^ 2)的复杂度应该是过不了的.斐波那契堆的实现相对 ...

  3. [转]Spring 注解大全与详解

    Spring使用的注解大全和解释 注解 解释 @Controller 组合注解(组合了@Component注解),应用在MVC层(控制层),DispatcherServlet会自动扫描注解了此注解的类 ...

  4. Vue 父组件与子组件的传值

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. Python--day41--守护线程

    1,守护线程:守护线程会在主线程结束之后等待其他子线程的结束才结束 拓展--守护进程:守护进程随着主进程代码的执行结束而结束 代码示例:守护线程.py import time from threadi ...

  6. 本地安装配置redis

    Windows中redis的下载及安装.设置   本文是转载自:https://www.cnblogs.com/jylee/p/9844965.html 下载地址: https://github.co ...

  7. Lavarel之环境配置 .env

    .env 文件位于项目根目录下,作为全局环境配置文件. 1. 配置参数 // 运行环境名称 APP_ENV=local // 调试模式,开发阶段启用,上线状态禁用. APP_DEBUG=true // ...

  8. ASP.NET MVC4.0+EF+LINQ+bui+网站+角色权限管理系统(6)

    快过年了,公司事情忙,好几天没有继续写博客,今天开始写账户模块系统登录,账户管理以及登录日志, 首先新建登录日志数据表: USE [MVCSystem] GO /****** Object: Tabl ...

  9. 洛谷4139 bzoj 3884 上帝与集合的正确用法

    传送门 •题意 求$2^{2^{2^{2^{2^{2^{...^{2}}}}}}}$ (无穷个2) 对p取模的值 •思路 设答案为f(p) $2^{2^{2^{2^{2^{2^{...^{2}}}}} ...

  10. Docker应用容器引擎

    1.Docker概述 1.1.Docker简介 Docker 是一个开源的应用容器引擎,基于 Go 语言开发.Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到 ...