https://www.lydsy.com/JudgeOnline/problem.php?id=1858

lxhgww最近收到了一个01序列,序列里面包含了n个数,这些数要么是0,要么是1,现在对于这个序列有五种变换操作和询问操作:

0 a b 把[a, b]区间内的所有数全变成0

1 a b 把[a, b]区间内的所有数全变成1

2 a b 把[a,b]区间内的所有数全部取反,也就是说把所有的0变成1,把所有的1变成0

3 a b 询问[a, b]区间内总共有多少个1

4 a b 询问[a, b]区间内最多有多少个连续的1

对于每一种询问操作,lxhgww都需要给出回答,聪明的程序员们,你们能帮助他吗?

线段树嘛,很裸的,正好趁自己神志不清试着来写写吧。

woc这线段树真恶心,2个标记维护7个量!

显然需要维护区间1个数,区间最大连续1。

为了合并还需要维护区间左最大连续1和右最大连续1.

为了取反还需要把上述东西的0也给求出来。

之后你愉快的敲起了数组线段树,结果发现你4操作写起来贼费劲。

靠!改结构体!

然后就是两个标记纠缠不清的问题了。

于是过了三次拍,debug了三次,终于过了……

2h+考场直接gg。

#include<map>
#include<cmath>
#include<stack>
#include<queue>
#include<cstdio>
#include<cctype>
#include<vector>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int N=1e5+;
const int p=1e9+;
inline int read(){
int X=,w=;char ch=;
while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
while(isdigit(ch))X=(X<<)+(X<<)+(ch^),ch=getchar();
return w?-X:X;
}
struct node{
int l,r,ls0,rs0,ls1,rs1;
int lz,sum,rng0,rng1;
bool rev;
}t[N*];
int n,m,b[N];
inline void upt(int a,int l,int r){
int mid=(l+r)>>,ls=a<<,rs=a<<|;
t[a].sum=t[ls].sum+t[rs].sum;
t[a].rng1=max(t[ls].rs1+t[rs].ls1,max(t[ls].rng1,t[rs].rng1));
t[a].rng0=max(t[ls].rs0+t[rs].ls0,max(t[ls].rng0,t[rs].rng0));
t[a].ls1=t[ls].ls1+(t[ls].ls1==mid-l+?t[rs].ls1:);
t[a].rs1=t[rs].rs1+(t[rs].rs1==r-mid?t[ls].rs1:);
t[a].ls0=t[ls].ls0+(t[ls].ls0==mid-l+?t[rs].ls0:);
t[a].rs0=t[rs].rs0+(t[rs].rs0==r-mid?t[ls].rs0:);
}
inline void turn(int a){
t[a].sum=t[a].r-t[a].l+-t[a].sum;
swap(t[a].ls1,t[a].ls0);
swap(t[a].rs1,t[a].rs0);
swap(t[a].rng1,t[a].rng0);
}
inline void change(int a,int w){
if(w){
t[a].ls1=t[a].rs1=t[a].sum=t[a].rng1=t[a].r-t[a].l+;
t[a].ls0=t[a].rs0=t[a].rng0=;
}
else{
t[a].ls0=t[a].rs0=t[a].rng0=t[a].r-t[a].l+;
t[a].ls1=t[a].rs1=t[a].sum=t[a].rng1=;
}
t[a].rev=;
}
inline void push(int a){
int ls=a<<,rs=a<<|;
if(t[a].lz!=-){
change(ls,t[a].lz);change(rs,t[a].lz);
t[ls].lz=t[rs].lz=t[a].lz;t[a].lz=-;
}
if(t[a].rev){
turn(ls);turn(rs);
t[ls].rev^=;t[rs].rev^=;t[a].rev=;
}
}
void build(int a,int l,int r){
t[a].lz=-;t[a].rev=;t[a].l=l;t[a].r=r;
if(l==r){
t[a].sum=b[l];
if(b[l])t[a].ls1=t[a].rs1=t[a].rng1=;
else t[a].ls0=t[a].rs0=t[a].rng0=;
return;
}
int mid=(l+r)>>;
build(a<<,l,mid);build(a<<|,mid+,r);
upt(a,l,r);
}
void modify(int a,int l,int r,int l1,int r1,int w){
if(r<l1||r1<l)return;
if(l1<=l&&r<=r1){
t[a].lz=w;change(a,w);
return;
}
push(a);
int mid=(l+r)>>;
modify(a<<,l,mid,l1,r1,w);
modify(a<<|,mid+,r,l1,r1,w);
upt(a,l,r);
}
void reverse(int a,int l,int r,int l1,int r1){
if(r<l1||r1<l)return;
if(l1<=l&&r<=r1){
t[a].rev^=;turn(a);
return;
}
push(a);
int mid=(l+r)>>;
reverse(a<<,l,mid,l1,r1);
reverse(a<<|,mid+,r,l1,r1);
upt(a,l,r);
}
int query_sum(int a,int l,int r,int l1,int r1){
if(r<l1||r1<l)return ;
if(l1<=l&&r<=r1)return t[a].sum;
push(a);
int mid=(l+r)>>;
return query_sum(a<<,l,mid,l1,r1)+
query_sum(a<<|,mid+,r,l1,r1);
}
node query_rng(int a,int l,int r,int l1,int r1){
if(l1==l&&r==r1)return t[a];
push(a);
int mid=(l+r)>>;
if(mid>=r1)return query_rng(a<<,l,mid,l1,r1);
else if(mid+<=l1)return query_rng(a<<|,mid+,r,l1,r1);
node lans=query_rng(a<<,l,mid,l1,mid);
node rans=query_rng(a<<|,mid+,r,mid+,r1);
node ans;
ans.l=lans.l;ans.r=rans.r;
ans.rng1=max(lans.rs1+rans.ls1,max(lans.rng1,rans.rng1));
ans.rng0=max(lans.rs0+rans.ls0,max(lans.rng0,rans.rng0));
ans.ls1=lans.ls1+(lans.ls1==mid-l+?rans.ls1:);
ans.rs1=rans.rs1+(rans.rs1==r-mid?lans.rs1:);
ans.ls0=lans.ls0+(lans.ls0==mid-l+?rans.ls0:);
ans.rs0=rans.rs0+(rans.rs0==r-mid?lans.rs0:);
return ans;
}
int main(){
n=read(),m=read();
for(int i=;i<=n;i++)b[i]=read();
build(,,n);
while(m--){
int op=read(),l=read()+,r=read()+;
if(op==)modify(,,n,l,r,);
if(op==)modify(,,n,l,r,);
if(op==)reverse(,,n,l,r);
if(op==)printf("%d\n",query_sum(,,n,l,r));
if(op==)printf("%d\n",query_rng(,,n,l,r).rng1);
}
return ;
}

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+

+++++++++++++++++++++++++++++++++++++++++++

BZOJ1858:[SCOI2010]序列操作——题解的更多相关文章

  1. BZOJ1858[Scoi2010]序列操作 题解

    题目大意: 有一个01序列,现在对于这个序列有五种变换操作和询问操作: 0 a b 把[a, b]区间内的所有数全变成0:1 a b 把[a, b]区间内的所有数全变成1:2 a b 把[a,b]区间 ...

  2. bzoj1858[Scoi2010]序列操作 线段树

    1858: [Scoi2010]序列操作 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 3079  Solved: 1475[Submit][Statu ...

  3. BZOJ1858 [Scoi2010]序列操作(线段树)

    题目链接 [Scoi2010]序列操作 考验代码能力的一道好题. 思想还是很简单的(直接上线段树),但是比较难写. #include <bits/stdc++.h> using names ...

  4. [BZOJ1858] [SCOI2010] 序列操作 解题报告 (线段树)

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1858 Description lxhgww最近收到了一个01序列,序列里面包含了n个数, ...

  5. 【分块】bzoj1858 [Scoi2010]序列操作

    分块 Or 线段树 分块的登峰造极之题 每块维护8个值: 包括左端点在内的最长1段: 包括右端点在内的最长1段: 该块内的最长1段: 该块内1的个数: 包括左端点在内的最长0段://这四个是因为可能有 ...

  6. bzoj1858: [Scoi2010]序列操作

    lazy-tag线段树. #include<cstdio> #include<algorithm> #include<cstring> using namespac ...

  7. bzoj千题计划177:bzoj1858: [Scoi2010]序列操作

    http://www.lydsy.com/JudgeOnline/problem.php?id=1858 2018 自己写的第1题,一遍过 ^_^ 元旦快乐 #include<cstdio> ...

  8. [待码][BZOJ1858]SCOI2010序列操作 jzyzoj1655

    待码的线段树.....太长了看上去不是很想写 [ 什么破理由啊摔,不要脸 ] 嗯先水几道再写

  9. bzoj1858 [Scoi2010]序列操作——线段树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1858 线段树...调了一个上午...(后面带 // 的都是改出来的) lazy 标记的下放好 ...

随机推荐

  1. 如何去除Eclipse下的JS引入报错(类似Syntax error on token...的异常信息)

    在Eclipse下引入外部JS文件,比如Jquery.js,经常会出现如下异常信息: 去除该异常方法: 1. 去掉Eclipse的JS验证 Windws---->Preferences----& ...

  2. 「日常训练」Balancing Act(POJ-1655)

    题意与分析 树的重心板子题. 值得考虑的是,重心究竟有哪些优秀的性质? 这里是一些网上能看到的性质: (判定性质)找到一个点,其所有的子树中最大的子树节点数最少(子树可以"倒着看" ...

  3. hdu2037今年暑假不AC(贪心,活动安排问题)

    今年暑假不AC Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submi ...

  4. 汽车VIN码,车架号,移动端,服务器端OCR识别 技术公司

    很多人在购买车辆的时候,只关注性能.外观.内饰等,其实真正的内行是首先看车辆的VIN码,也叫车架号码. VIN码(车架号码)是一辆车的唯一身份证明,一般在车辆的挡风玻璃处,有的在车辆防火墙上,或B柱铭 ...

  5. Qt-第一个QML程序-1-项目工程的建立

    这个小程序是我发的第一个完整的QMl程序,这个程序也会持续的更新,一步一步的完善起来,最后会有一个什么样的结果也是不知道,只是把自己目前掌握的QML相关的东西都慢慢的写进来,积累起来 先展示一下运行结 ...

  6. 第三篇 JavaScript基础

    知识预览 BOM对象 DOM对象(DHTML) 实例练习 转:https://www.cnblogs.com/yuanchenqi/articles/5980312.html#_label2 一.Ja ...

  7. Java开发工程师(Web方向) - 01.Java Web开发入门 - 第4章.Maven

    第4章--Maven Maven实战 Java Web应用的部署: 手动式: 编译:javac -cp $CATALINA_HOME/lib/servlet-api.jar web-inf/class ...

  8. NMAP-主机扫描

    1.全面扫描 2.扫描指定段 3.ping扫描 只进行ping操作,十分隐蔽 4.无ping扫描 适用于防火墙禁止ping 5.TCP SYN扫描 6.TCP ACK扫描 7.UDP扫描 8.ICMP ...

  9. Mishka and Contest(模拟水题)

    Mishka started participating in a programming contest. There are nn problems in the contest. Mishka' ...

  10. psp1111

    1 本周psp 2.本周进度条 3.本周累积进度图 代码累积折线图 博文字数累积折线图 4.本周PSP饼状图