好久没写线段树了。。被一道线段树裸题卡了一个上午

对区间进行异或,查询的时候直接用区间长度减去原有是数量就是改变完的数量

#include<bits/stdc++.h>
using namespace std;
#define maxn 100005
struct tree{
int l,r,sum;
}t[maxn*];
int n,m,ans;
int lazy[maxn*],a[maxn];
void add(int x,int l,int r){
lazy[x]^=;
t[x].sum=(r-l+)-t[x].sum;
}
void build(int x,int l,int r){
t[x].l=l;
t[x].r=r;
if(l==r){
return;
}
int mid=(l+r)>>;
build(x*,l,mid);
build(x*+,mid+,r);
}
void push(int x){
if(lazy[x]){
int mid=(t[x].l+t[x].r)>>;
add(x*,t[x].l,mid);add(x*+,mid+,t[x].r);
lazy[x]=;
}
}
int query(int x,int l,int r){
if(l<=t[x].l&&r>=t[x].r){
return t[x].sum;
}
if(l>t[x].r||r<t[x].l)
return ;
push(x);
return query(x*,l,r)+query(x*+,l,r);
}
void change(int x,int l,int r){
if(l<=t[x].l&&r>=t[x].r){
add(x,t[x].l,t[x].r);
return ;
}
if(l>t[x].r||r<t[x].l) return ;
push(x);
int mid=(t[x].l+t[x].r)>>;
change(x*,l,r);
change(x*+,l,r);
t[x].sum=t[x*].sum+t[x*+].sum;
}
int main(){
scanf("%d%d",&n,&m);
int x,y,z;
build(,,n);
for(int i=;i<=m;i++){
scanf("%d%d%d",&x,&y,&z);
if(x==){
ans=query(,y,z);
printf("%d\n",ans);
}
else {
change(,y,z);
/*printf("\n{");
for(int i=1;i<=7;i++){
cout<<t[i].sum<<" ";
}
printf("}\n");*/
}
} return ;
}

bzoj1230 开关灯 线段树的更多相关文章

  1. BZOJ 1230: [Usaco2008 Nov]lites 开关灯( 线段树 )

    线段树.. --------------------------------------------------------------------------------- #include< ...

  2. codevs 1690 开关灯 线段树+延迟标记

    1690 开关灯  时间限制: 1 s  空间限制: 128000 KB   题目描述 Description YYX家门前的街上有N(2<=N<=100000)盏路灯,在晚上六点之前,这 ...

  3. codevs 1690 开关灯 线段树区间更新 区间查询Lazy

    题目描述 Description YYX家门前的街上有N(2<=N<=100000)盏路灯,在晚上六点之前,这些路灯全是关着的,六点之后,会有M(2<=m<=100000)个人 ...

  4. B1230 [Usaco2008 Nov]lites 开关灯 线段树

    就是线段树维护异或和.之前我线段树区间修改down都是修改当前区间,结果debug出不来,改成每次向下了. 题干: Description Farmer John尝试通过和奶牛们玩益智玩具来保持他的奶 ...

  5. BZOJ 1230 Usaco2008 Nov 开关灯 线段树

    思路: 用线段树模拟题中的操作就好 (标记异或 长度=区间总长度-当前已开灯的长度) //By SiriusRen #include <cstdio> using namespace st ...

  6. 【codevs1690】开关灯 线段树

    这道题需要支持区间修改和区间询问,因此采用线段树加以维护. 由于求的是开着的灯的数目,因此维护sum:区间[ l , r ]中开着的灯的数目. tag取做0/1,表示区间是否反转,在进行标记下传时,如 ...

  7. 【codevs1690】开关灯 线段树 区间修改+区间求和(标记)

    [codevs1690]开关灯 2014年2月15日4930 题目描述 Description YYX家门前的街上有N(2<=N<=100000)盏路灯,在晚上六点之前,这些路灯全是关着的 ...

  8. codevs1690 开关灯(线段树)

    1690 开关灯 USACO  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond     题目描述 Description YYX家门前的街上有N(2< ...

  9. codevs 1690 开关灯 线段树水题

    没什么好说的,标记put表示开关是否开着. #include<cstdio> #include<cstring> #include<algorithm> using ...

随机推荐

  1. xBIM 基础14 使用LINQ实现最佳性能(优化查询)

    系列目录    [已更新最新开发文章,点击查看详细]  LINQ代表语言集成查询,它是3.5版以来的.NET Framework的一部分.它实现延迟执行,这意味着您可以链接查询语句,并且在您实际迭代结 ...

  2. MapReduce 程序:WordCount

  3. 【原创】Unable to read TLD "META-INF/c.tld" from JAR file 解决方法

    type Exception report message description The server encountered an internal error () that prevented ...

  4. HDU 1087 Super Jumping! Jumping! Jumping!【DP】

    解题思路:题目的大意是给出一列数,求这列数里面最长递增数列的和 dp[i]表示到达地点i的最大值,那么是如何达到i的呢,则我们可以考虑没有限制条件时候的跳跃,即可以从第1,2,3,---,i-1个地点 ...

  5. shell-3.bash的基本功能:通配符和其他特殊字符

    1. 2.

  6. Linxu基本指令

    一.Linux权限的概念 Linux下有两种用户:普通用户和超级用户(). 普通用户:在linux下做有限的事情: 超级用户:可以在linux系统下做任何事情,不受限制. 普通用户的提示符是“$”,超 ...

  7. apicloud 上传/更新App版本到 ios store 流程步骤

    app更新 上传APP的地址: https://itunesconnect.apple.com/login 苹果开发者中心: https://developer.apple.com/ app正式包更新 ...

  8. caioj 1153 扩展欧几里德算法(解不定方程)

    模板题 注意exgcd函数要稍微记一下 #include<cstdio> #include<cctype> #include<algorithm> #define ...

  9. mysql给某字段随机赋特定范围的整数值

    [引] mysql中随机生成一些范围内的整数有时候是很有用的,用到了2个函数 1.floor(f) 返回一个不大于f的最大整数 2.rand(),rand(n) 返回一个随机浮点值 v ,范围在 0  ...

  10. 蓝的成长记——追逐DBA(18):小机上WAS集群故障,由一次更换IP引起

    原创作品.出自 "深蓝的blog" 博客,欢迎转载,转载时请务必注明出处.否则追究版权法律责任. 深蓝的blog:http://blog.csdn.net/huangyanlong ...