FZU 2105 Digits Count(按位维护线段树)
【题目链接】 http://acm.fzu.edu.cn/problem.php?pid=2105
【题目大意】
给出一个序列,数字均小于16,为正数,每次区间操作可以使得
1. [l,r]区间and一个数
2. [l,r]区间or一个数
3. [l,r]区间xor一个数
4. [l,r]区间查询和
操作数均为小于16的非负整数
【题解】
由于操作数很小,因此我们可以按位维护四棵线段树,表示二进制中的第i位,
对于and操作,只有当and的当前位为0时才对区间有影响,效果是将区间全部变为0,
对于or和xor操作,当前位为1的时候才对区间有影响,
因为and和or是全区间变化为同一个值,因此区间和会变为全区间或者0,
那么and和or的变化只需要看父区间的值来决定子区间的变化而不需要标记传递
对于xor操作,相当于区间01翻转,用一个标记记录翻转次数即可,
【代码】
#include <cstdio>
#include <algorithm>
using namespace std;
const int N=1000010;
int T[4][N<<2],tag[4][N<<2],a[N];
void up(int k,int x){T[k][x]=T[k][x<<1]+T[k][x<<1|1];}
void pb(int k,int x,int l,int r){
int mid=(l+r)>>1;
if(T[k][x]==r-l+1){T[k][x<<1]=mid-l+1;T[k][x<<1|1]=r-mid;}
if(!T[k][x]){T[k][x<<1]=T[k][x<<1|1]=0;}
if(tag[k][x]){
tag[k][x]^=1;
if(T[k][x]!=r-l+1&&T[k][x]){
T[k][x<<1]=mid-l+1-T[k][x<<1];
T[k][x<<1|1]=r-mid-T[k][x<<1|1];
}tag[k][x<<1]^=1;tag[k][x<<1|1]^=1;
}
}
void build(int k,int x,int l,int r){
int mid=(l+r)>>1;
tag[k][x]=0;
if(l==r){T[k][x]=(a[l]>>k)&1;return;}
build(k,x<<1,l,mid);build(k,x<<1|1,mid+1,r);
up(k,x);
}
void update(int k,int x,int l,int r,int L,int R,char op){
int mid=(l+r)>>1;
if(L<=l&&r<=R){
if(op=='A')T[k][x]=0;
if(op=='O')T[k][x]=r-l+1;
if(op=='X')T[k][x]=(r-l+1)-T[k][x],tag[k][x]^=1;
return;
}pb(k,x,l,r);
if(L<=mid)update(k,x<<1,l,mid,L,R,op);
if(mid+1<=R)update(k,x<<1|1,mid+1,r,L,R,op);
up(k,x);
}
int query(int k,int x,int l,int r,int L,int R){
int mid=(l+r)>>1;
if(L<=l&&r<=R)return T[k][x]; pb(k,x,l,r);
int res=0;
if(L<=mid)res+=query(k,x<<1,l,mid,L,R);
if(mid+1<=R)res+=query(k,x<<1|1,mid+1,r,L,R);
return res;
}
int Cas,n,m;
char op[10];
int main(){
scanf("%d",&Cas);
while(Cas--){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)scanf("%d",&a[i]);
for(int i=0;i<4;i++)build(i,1,1,n);
while(m--){
scanf("%s",op);
if(op[0]=='S'){
int l,r,ans=0;
scanf("%d%d",&l,&r);
l++;r++;
for(int i=0;i<4;i++)ans+=query(i,1,1,n,l,r)*(1<<i);
printf("%d\n",ans);
}else{
int l,r,x;
scanf("%d%d%d",&x,&l,&r); l++,r++;
for(int i=0;i<4;i++)if((op[0]=='A')^((x>>i)&1))update(i,1,1,n,l,r,op[0]);
}
}
}return 0;
}
FZU 2105 Digits Count(按位维护线段树)的更多相关文章
- ACM: FZU 2105 Digits Count - 位运算的线段树【黑科技福利】
FZU 2105 Digits Count Time Limit:10000MS Memory Limit:262144KB 64bit IO Format:%I64d & ...
- FZU 2105 Digits Count(线段树)
Problem 2105 Digits Count Accept: 302 Submit: 1477 Time Limit: 10000 mSec Memory Limit : 262144 KB P ...
- FZU 2105 Digits Count
Problem 2105 Digits Count Accept: 444 Submit: 2139 Time Limit: 10000 mSec Memory Limit : 2621 ...
- FZU 2105 Digits Count(位数计算)
Description 题目描述 Given N integers A={A[0],A[1],...,A[N-1]}. Here we have some operations: Operation ...
- fzu 2105 Digits Count ( 线段树 ) from 第三届福建省大学生程序设计竞赛
http://acm.fzu.edu.cn/problem.php?pid=2105 Problem Description Given N integers A={A[0],A[1],...,A[N ...
- FZU2105 Digits Count(按位建线段树)题解
题意: 给出区间与.或.异或\(x\)操作,还有询问区间和. 思路: 因为数比较小,我们给每一位建线段树,这样每次只要更新对应位的答案. 与\(0\)和或\(1\)相当于重置区间,异或\(1\)相当于 ...
- 【GDKOI2016Day1T1-魔卡少女】【拆位】线段树维护区间内所有连续子区间的异或和
题意:给出N个数,M个操作.操作有修改和询问两种,每次修改将一个数改成另一个数,每次询问一个区间的所有连续子区间的异或和.n,m<=100000,ai<=1000 题解: 当年(其实也就是 ...
- FOJ 2105 Digits Count
题意:对一串数字进行抑或某数,和某数,或某数,统计某区间和的操作. 思路:因为化成二进制就4位可以建4颗线段树,每颗代表一位二进制. and 如果该为是1 直接无视,是0则成段赋值为0: or 如 ...
- HDU 6155 Subsequence Count(矩阵乘法+线段树+基础DP)
题意 给定一个长度为 \(n\) 的 \(01\) 串,完成 \(m\) 种操作--操作分两种翻转 \([l,r]\) 区间中的元素.求区间 \([l,r]\) 有多少个不同的子序列. \(1 \le ...
随机推荐
- bzoj 3343 分块
因为询问比较少,所以我们可以将n个数分成sqrt(n)个块,每个块用一颗bst存一下,然后对于修改l,r,我们将l,r区间中整块的直接在bst上打一个标签,对于不是整块的我们直接暴力修改,对于询问l, ...
- Less & Sass
CSS不是一种编程语言.它开发网页样式,但是没法用它编程.也就是说,CSS基本上是设计师的工具,它没有变量,也没有条件语句,只是一行行单纯的描述.有人就开始为CSS加入编程元素,这被叫做"C ...
- Yii 1.1.17 二、Gii创建后台与后台登录验证
一.用Gii创建后台模块 1.启用gii,在config/main.php 'gii' => array( 'class' => 'system.gii.GiiModule', 'pass ...
- VPS L2TP配置
原文地址:https://raymii.org/s/tutorials/IPSEC_L2TP_vpn_with_Ubuntu_14.04.html 只要保证ipsec verify没错,基本都可以成功 ...
- C后端设计开发 - 第4章-武技-常见轮子下三路
正文 第4章-武技-常见轮子下三路 后记 如果有错误, 欢迎指正. 有好的补充, 和疑问欢迎交流, 一块提高. 在此谢谢大家了. Moonlight Shadow 纪念那个我爱的, 被我感动的女孩 ...
- CSS原生布局方式
前言 网页原生布局的方法其实网上有很多,大概为Flow(流动布局模型).Float(浮动布局模型).Layer(层级布局模型).<!--more--> Flow布局 流动布局模型其实就是默 ...
- pdf2htmlEX安装和配置
1.下载 安装的依赖: sudo yum install cmake gcc gnu-getopt java-1.8.0-openjdk libpng-devel fontforge-devel ca ...
- Django Ajax学习二之csrf跨站请求伪造
方式1 $.ajaxSetup({ data: {csrfmiddlewaretoken: '{{ csrf_token }}' }, }); 方式2 # html文件from表单中<form& ...
- JS将日期转换为yyyy-MM-dd HH:mm:ss
//格式化后日期为:yyyy-MM-dd HH:mm:ss function FormatAllDate(sDate) { var date = new Date(sDate); var sepera ...
- BestCoder Round #86 二,三题题解(尺取法)
第一题太水,跳过了. NanoApe Loves Sequence题目描述:退役狗 NanoApe 滚回去学文化课啦! 在数学课上,NanoApe 心痒痒又玩起了数列.他在纸上随便写了一个长度为 nn ...