bzoj1858: [Scoi2010]序列操作
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]序列操作的更多相关文章
- bzoj1858[Scoi2010]序列操作 线段树
1858: [Scoi2010]序列操作 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 3079 Solved: 1475[Submit][Statu ...
- BZOJ1858 [Scoi2010]序列操作(线段树)
题目链接 [Scoi2010]序列操作 考验代码能力的一道好题. 思想还是很简单的(直接上线段树),但是比较难写. #include <bits/stdc++.h> using names ...
- BZOJ1858[Scoi2010]序列操作 题解
题目大意: 有一个01序列,现在对于这个序列有五种变换操作和询问操作: 0 a b 把[a, b]区间内的所有数全变成0:1 a b 把[a, b]区间内的所有数全变成1:2 a b 把[a,b]区间 ...
- [BZOJ1858] [SCOI2010] 序列操作 解题报告 (线段树)
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1858 Description lxhgww最近收到了一个01序列,序列里面包含了n个数, ...
- 【分块】bzoj1858 [Scoi2010]序列操作
分块 Or 线段树 分块的登峰造极之题 每块维护8个值: 包括左端点在内的最长1段: 包括右端点在内的最长1段: 该块内的最长1段: 该块内1的个数: 包括左端点在内的最长0段://这四个是因为可能有 ...
- bzoj千题计划177:bzoj1858: [Scoi2010]序列操作
http://www.lydsy.com/JudgeOnline/problem.php?id=1858 2018 自己写的第1题,一遍过 ^_^ 元旦快乐 #include<cstdio> ...
- [待码][BZOJ1858]SCOI2010序列操作 jzyzoj1655
待码的线段树.....太长了看上去不是很想写 [ 什么破理由啊摔,不要脸 ] 嗯先水几道再写
- bzoj1858 [Scoi2010]序列操作——线段树
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1858 线段树...调了一个上午...(后面带 // 的都是改出来的) lazy 标记的下放好 ...
- 【BZOJ-1858】序列操作 线段树
1858: [Scoi2010]序列操作 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1961 Solved: 991[Submit][Status ...
随机推荐
- JavaScript笔记(二)——常用数组、字符串方法的应用
1.将字符串中的字符翻转,比如'hello',翻转成'olleh'. var arr=[]; function reverseString(str) { arr=str.split("&qu ...
- ecshop 全站自定义title标题
对于SEO来说,能让标题自定义的将会大大增加SEO效果,提高独立商城的流量,今天小编就收集从网上弄来ecshop全站自定义代码,很全哦! 1.Ecshop商品分类页如何实现自定义Title 最近发现很 ...
- python3 pyqt5 和eric5配置教程
一.大纲内容: 1.预备PC环境: 2.预备安装程序: 2.1.下载Python3.2 2.2.下载PyQt4 2.3.下载Eric5 3.安装配置步骤: 3.1.安装Pyhon3.2 3.2.安装P ...
- Mysql数据库备份和还原常用的命令
Mysql数据库备份和还原常用的命令是进行Mysql数据库备份和还原的关键,没有命令,什么都无从做起,更谈不上什么备份还原,只有给系统这个命令,让它去执行,才能完成Mysql数据库备份和还原的操作,下 ...
- [转]SqlServer数据库同步方案详解
SqlServer数据库同步是项目中常用到的环节,若一个项目中的数据同时存在于不同的数据库服务器中,而这些数据库需要被多个不同的网域调用时,配置 SqlServer数据库同步是个比较好的解决方案.Sq ...
- GPS导航仪常见术语解释
摘自百度百科: 坐标(coordinate) 有2维.3维两种坐标表示,当GPS能够收到4颗及以上卫星的信号时,它能计算出本地的3维坐标:经度.纬度.高度,若只能收到3颗卫星的信号,它只能计算出2维坐 ...
- [转载].Net中如何操作IIS(源代码)
///***********************************************************///************** IIS控制管理类 1.0 Beta ** ...
- linux下执行 ls,cat等一些命令报出 -bash: /bin/cat: Cannot allocate memory 有没解决的方法
环境变量配置出错了cd -- 进入用户目录vim .bash_profile删除以前PATH这一行,把下面的粘帖进去PATH=$PATH:$HOME/bin:/root:/root/snapshot/ ...
- 如何在Ubuntu下搭建Android NDK开发环境
1 搭建Android SDK开发环境 参考在在Ubuntu下搭建Android SDK开发环境(图文)首先在Ubuntu下搭建Android SDK开发环境. 2 下载NDK开发包 打开官网: ht ...
- hdu 4558 剑侠情缘
思路:dp[i][j][k]表示在点(i,j)处能量的差值为k的方案数 转移的时候把差值取相反数就实现轮流了 代码如下: #include<iostream> #include<st ...