lazy-tag线段树。

#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
const int maxn = 800000 + 10; struct Segtree {
#define lc(x) ((x)<<1)
#define rc(x) (((x)<<1)|1) int l[maxn],r[maxn];
int l1[maxn],r1[maxn],con1[maxn],cnt1[maxn];
int l0[maxn],r0[maxn],con0[maxn];
int t1[maxn],t0[maxn],tr[maxn]; void set1(int x) {
l1[x]=r1[x]=con1[x]=cnt1[x]=r[x]-l[x]+1;
l0[x]=r0[x]=con0[x]=0;
t1[x]=1; t0[x]=tr[x]=0;
} void set0(int x) {
l0[x]=r0[x]=con0[x]=r[x]-l[x]+1;
l1[x]=r1[x]=con1[x]=cnt1[x]=0;
t0[x]=1; t1[x]=tr[x]=0;
} void inv(int x) {
swap(l1[x],l0[x]);
swap(r1[x],r0[x]);
swap(con1[x],con0[x]);
cnt1[x]=r[x]-l[x]+1-cnt1[x];
tr[x]^=1;
} void push(int x) {
if(t0[x]) {
set0(lc(x));
set0(rc(x));
t0[x]=0;
}
if(t1[x]) {
set1(lc(x));
set1(rc(x));
t1[x]=0;
}
if(tr[x]) {
inv(lc(x));
inv(rc(x));
tr[x]=0;
}
} void update(int x) {
l1[x]=(l1[lc(x)]==r[lc(x)]-l[lc(x)]+1?l1[lc(x)]+l1[rc(x)]:l1[lc(x)]);
r1[x]=(r1[rc(x)]==r[rc(x)]-l[rc(x)]+1?r1[rc(x)]+r1[lc(x)]:r1[rc(x)]);
l0[x]=(l0[lc(x)]==r[lc(x)]-l[lc(x)]+1?l0[lc(x)]+l0[rc(x)]:l0[lc(x)]);
r0[x]=(r0[rc(x)]==r[rc(x)]-l[rc(x)]+1?r0[rc(x)]+r0[lc(x)]:r0[rc(x)]);
con1[x]=max(max(con1[lc(x)],con1[rc(x)]),r1[lc(x)]+l1[rc(x)]);
con0[x]=max(max(con0[lc(x)],con0[rc(x)]),r0[lc(x)]+l0[rc(x)]);
cnt1[x]=cnt1[lc(x)]+cnt1[rc(x)];
} void op0(int x,int L,int R) {
push(x);
if(R<l[x] || L>r[x]) return;
if(L<=l[x] && r[x]<=R) {
set0(x);
return;
}
op0(lc(x),L,R);
op0(rc(x),L,R);
update(x);
} void op1(int x,int L,int R) {
push(x);
if(R<l[x] || L>r[x]) return;
if(L<=l[x] && r[x]<=R) {
set1(x);
return;
}
op1(lc(x),L,R);
op1(rc(x),L,R);
update(x);
} void op2(int x,int L,int R) {
push(x);
if(R<l[x] || L>r[x]) return;
if(L<=l[x] && r[x]<=R) {
inv(x);
return;
}
op2(lc(x),L,R);
op2(rc(x),L,R);
update(x);
} int op3(int x,int L,int R) {
push(x);
if(R<l[x] || L>r[x]) return 0;
if(L<=l[x] && r[x]<=R) return cnt1[x];
return(op3(lc(x),L,R)+op3(rc(x),L,R));
} int op4(int x,int L,int R) {
push(x);
if(R<l[x] || L>r[x]) return 0;
if(L<=l[x] && r[x]<=R) return con1[x];
return max(max(op4(lc(x),L,R),op4(rc(x),L,R)),min(r1[lc(x)],r[lc(x)]-L+1)+min(l1[rc(x)],R-l[rc(x)]+1));
} void build(int x,int L,int R) {
l[x]=L; r[x]=R;
if(L==R) {
int k;
scanf("%d",&k);
if(k) l1[x]=r1[x]=con1[x]=cnt1[x]=1;
else l0[x]=r0[x]=con0[x]=1;
return;
}
int mid=(L+R)>>1;
build(lc(x),L,mid);
build(rc(x),mid+1,R);
update(x);
}
}seg;
int n,m; int main() {
scanf("%d%d",&n,&m);
seg.build(1,0,n-1);
for(int i=1,op,a,b;i<=m;i++) {
scanf("%d%d%d",&op,&a,&b);
if(op==0) seg.op0(1,a,b);
else if(op==1) seg.op1(1,a,b);
else if(op==2) seg.op2(1,a,b);
else if(op==3) printf("%d\n",seg.op3(1,a,b));
else if(op==4) printf("%d\n",seg.op4(1,a,b));
}
return 0;
}

bzoj1858: [Scoi2010]序列操作的更多相关文章

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

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

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

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

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

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

  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. bzoj千题计划177:bzoj1858: [Scoi2010]序列操作

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

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

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

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

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

  9. 【BZOJ-1858】序列操作 线段树

    1858: [Scoi2010]序列操作 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 1961  Solved: 991[Submit][Status ...

随机推荐

  1. 图片grayscale(灰阶效果)webkit内核支持。

    filter:gray;-webkit-filter: grayscale(100%); 置为灰阶等hove时候 -webkit-filter: grayscale(0%);显示出彩色.

  2. VB 核心编程及通用模块开发 笔记1

    前言:学习任何编程语言.编程工具的目的不外乎解决生活问题,能够快速.高效解决问题的方式就是不错的方式,至于选择什么“工具”,众位看官看着办,本人虽然有过3年vb开发经验,但是一直没有深入学习,现已购买 ...

  3. Python 基础篇:介绍

    1. Python 发展 1989年,为了打发圣诞节假期,Guido开始写Python语言的编译器.Python这个名字,来自Guido所挚爱的电视剧Monty Python's Flying Cir ...

  4. vim使用总结

    tar -xf vim.tar -C ~ vim /etc/vimrc vim /root/.vimrc set ts=4 设置tab有多少空格 set ai 自动对齐 set nu set mous ...

  5. mac 下 sphinx + mysql + php 实现全文搜索(xampp)(1)

      原理: 使用sphinx 中的indexer 生成索引数据 service/web 端 利用searched 调用索引数据 步骤: 下载 sphinx: 下载地址:http://sphinxsea ...

  6. mac上xampp配置

    sudo su /Applications/XAMPP/xamppfiles/xampp security

  7. Java学习之路:1、HelloWorld

    似乎每种语言都是从HelloWorld开始的,所以,我的第一个java程序,也应该是这样开始的! 1.配置好jdk后,开始编写HelloWorld.java package second;//这个应该 ...

  8. 【Entity Framework 7】 完全不一样的玩法

    http://www.cnblogs.com/n-pei/p/4274907.html

  9. sharepoint 2010 masterpage中必须的Content PlaceHolder

    Professional SharePoint 2010 Branding and Use

  10. linux驱动系列之tftp(转)

    转自网页:http://blog.csdn.net/xingyu19871124/article/details/7315893 最近在将做的嵌入式项目移植到ARM开发板上,宿主机用的ubuntu11 ...