题面

线段树......模板题(雾?

然而两种标记会互相影响,必须保证每次只放一个(不然就不知道怎么放了),具体的影响就是:

翻转标记会使得覆盖标记一起翻转,下放的时候就是各种swap

覆盖标记会抹掉翻转标记,下放的时候好像挺正常的

然后就是码码码+细节

 #include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=;
struct a{int ll,rr,vv;};
int val[*N],last[*N][],lst[*N][],rst[*N][];
int num[N],laz1[*N],laz2[*N];
int n,m,t1,t2,t3;
void pushup(int nde,int l,int r)
{
int mid=(l+r)/,ls=*nde,rs=*nde+;
val[nde]=val[ls]+val[rs];
//value
lst[nde][]=(last[ls][]==mid-l+)?last[ls][]+lst[rs][]:lst[ls][];
rst[nde][]=(last[rs][]==r-mid)?last[rs][]+rst[ls][]:rst[rs][];
last[nde][]=max(rst[ls][]+lst[rs][],max(last[ls][],last[rs][]));
//longest continuing one
lst[nde][]=(last[ls][]==mid-l+)?last[ls][]+lst[rs][]:lst[ls][];
rst[nde][]=(last[rs][]==r-mid)?last[rs][]+rst[ls][]:rst[rs][];
last[nde][]=max(rst[ls][]+lst[rs][],max(last[ls][],last[rs][]));
//longest continuing zero
}
void create(int nde,int l,int r)
{
if(l==r)
{
last[nde][]=lst[nde][]=rst[nde][]=(num[l]^);
val[nde]=last[nde][]=lst[nde][]=rst[nde][]=num[l];
}
else
{
int mid=(l+r)/,ls=*nde,rs=*nde+;
create(ls,l,mid),create(rs,mid+,r);
pushup(nde,l,r);
}
}
void release(int nde,int l,int r)
{
int mid=(l+r)/,ls=*nde,rs=*nde+;
if(laz2[nde])
{
if(~laz1[ls]) laz1[ls]^=; else laz2[ls]^=;
if(~laz1[rs]) laz1[rs]^=; else laz2[rs]^=;
val[ls]=(mid-l+)-val[ls],val[rs]=(r-mid)-val[rs];
//reversing
swap(last[ls][],last[ls][]),swap(last[rs][],last[rs][]);
swap(lst[ls][],lst[ls][]),swap(lst[rs][],lst[rs][]);
swap(rst[ls][],rst[ls][]),swap(rst[rs][],rst[rs][]);
//a lot of swaps......
laz2[nde]=;
//refresh
}
//release the lazy tag of intervals reversing
else if(~laz1[nde])
{
laz1[ls]=laz1[nde],laz1[rs]=laz1[nde],laz2[ls]=,laz2[rs]=;
//to the left/right son
val[ls]=last[ls][]=lst[ls][]=rst[ls][]=(mid-l+)*laz1[nde];
val[rs]=last[rs][]=lst[rs][]=rst[rs][]=(r-mid)*laz1[nde];
//longest continuing one
last[ls][]=lst[ls][]=rst[ls][]=(mid-l+)*(laz1[nde]^);
last[rs][]=lst[rs][]=rst[rs][]=(r-mid)*(laz1[nde]^);
//longest continuing zero
laz1[nde]=-;
//refresh
}
//release the lazy tag of intervals covering
}
void Change(int nde,int l,int r,int nl,int nr,int task)
{
if(l>nr||r<nl)
return ;
else if(l>=nl&&r<=nr)
{
last[nde][]=lst[nde][]=rst[nde][]=(task^)*(r-l+);
val[nde]=last[nde][]=lst[nde][]=rst[nde][]=task*(r-l+);
laz1[nde]=task,laz2[nde]=;
}
else
{
int mid=(l+r)/,ls=*nde,rs=*nde+; release(nde,l,r);
Change(ls,l,mid,nl,nr,task),Change(rs,mid+,r,nl,nr,task);
pushup(nde,l,r);
}
}
void Reverse(int nde,int l,int r,int nl,int nr)
{
if(l>nr||r<nl)
return ;
else if(l>=nl&&r<=nr)
{
val[nde]=(r-l+)-val[nde],swap(last[nde][],last[nde][]);
swap(lst[nde][],lst[nde][]),swap(rst[nde][],rst[nde][]);
if(~laz1[nde]) laz1[nde]^=; else laz2[nde]^=;
}
else
{
int mid=(l+r)/,ls=*nde,rs=*nde+; release(nde,l,r);
Reverse(ls,l,mid,nl,nr),Reverse(rs,mid+,r,nl,nr); pushup(nde,l,r);
}
}
int Vquery(int nde,int l,int r,int nl,int nr)
{
if(l>nr||r<nl)
return ;
else if(l>=nl&&r<=nr)
return val[nde];
else
{
int mid=(l+r)/,ls=*nde,rs=*nde+; release(nde,l,r);
return Vquery(ls,l,mid,nl,nr)+Vquery(rs,mid+,r,nl,nr);
}
}
a Lquery(int nde,int l,int r,int nl,int nr)
{
if(l>=nl&&r<=nr)
return (a){lst[nde][],rst[nde][],last[nde][]};
else
{
int mid=(l+r)/,ls=*nde,rs=*nde+; release(nde,l,r);
if(nr<=mid) return Lquery(ls,l,mid,nl,nr);
if(nl>mid) return Lquery(rs,mid+,r,nl,nr);
a Q1=Lquery(ls,l,mid,nl,nr),Q2=Lquery(rs,mid+,r,nl,nr),ret;
ret.vv=max(max(Q1.vv,Q2.vv),Q1.rr+Q2.ll);
ret.ll=(Q1.vv==(mid-l+))?Q1.vv+Q2.ll:Q1.ll;
ret.rr=(Q2.vv==(r-mid))?Q2.vv+Q1.rr:Q2.rr;
return ret;
}
}
int main ()
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
scanf("%d",&num[i]);
create(,,n);
memset(laz1,-,sizeof laz1);
for(int i=;i<=m;i++)
{
scanf("%d%d%d",&t1,&t2,&t3),t2++,t3++;
if(!t1) Change(,,n,t2,t3,);
else if(t1==) Change(,,n,t2,t3,);
else if(t1==) Reverse(,,n,t2,t3);
else if(t1==) printf("%d\n",Vquery(,,n,t2,t3));
else printf("%d\n",Lquery(,,n,t2,t3).vv);
}
return ;
}

解题:SCOI 2010 序列操作的更多相关文章

  1. SCOI 2010 序列操作

    题目描述 lxhgww最近收到了一个01序列,序列里面包含了n个数,这些数要么是0,要么是1,现在对于这个序列有五种变换操作和询问操作: 0 a b 把[a, b]区间内的所有数全变成0 1 a b ...

  2. SCOI2010 序列操作

    2421 序列操作 http://codevs.cn/problem/2421/ 2010年省队选拔赛四川   题目描述 Description lxhgww最近收到了一个01序列,序列里面包含了n个 ...

  3. 1858: [Scoi2010]序列操作

    1858: [Scoi2010]序列操作 Time Limit: 10 Sec Memory Limit: 64 MB Submit: 3397 Solved: 1624 [Submit][Statu ...

  4. Python通用序列操作

    1.序列概览 1.数据结构 序列.容器 Python中最基本的数据结构是序列,其有索引(从左到右第一个索引为0,从右到左第一个索引为-1). Python包含6中内建的序列: 列表 元组 字符串 Un ...

  5. 【BZOJ-2962】序列操作 线段树 + 区间卷积

    2962: 序列操作 Time Limit: 50 Sec  Memory Limit: 256 MBSubmit: 678  Solved: 246[Submit][Status][Discuss] ...

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

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

  7. bzoj 1858: [Scoi2010]序列操作

    1858: [Scoi2010]序列操作 Time Limit: 10 Sec  Memory Limit: 64 MB 线段树,对于每个区间需要分别维护左右和中间的1和0连续个数,并在op=4时特殊 ...

  8. BZOJ 1858: [Scoi2010]序列操作( 线段树 )

    略恶心的线段树...不过只要弄清楚了AC应该不难.... ---------------------------------------------------------------- #inclu ...

  9. [bzoj]2962序列操作

    [bzoj]2962序列操作 标签: 线段树 题目链接 题意 给你一串序列,要你维护三个操作: 1.区间加法 2.区间取相反数 3.区间内任意选k个数相乘的积 题解 第三个操作看起来一脸懵逼啊. 其实 ...

随机推荐

  1. ltrace命令详解

    原文链接:https://ipcmen.com/ltrace 用来跟踪进程调用库函数的情况 补充说明 NAME       ltrace - A library call tracer ltrace命 ...

  2. 解决 vuex mapGetters 语法报错 (Unexpected token )

    在使用vuex2的mapGetters 和 mapActions 的方法时,借助 stage2 的 Object Rest Operator 特性,可以写出下面代码:  computed: { ... ...

  3. Scrum Meeting 11.03

    成员 今日任务 明日计划 用时 徐越 休息     赵庶宏 编写功能说明书,servlet代码移植 servlet代码移植 3h 薄霖 阅读上一届相关代码,思考改进方法 学习安卓界面设计数据库管理 4 ...

  4. 2-Third Scrum Meeting-20151203

    任务安排 闫昊: 今日完成:请假.(编译+计组,压力有点大) 明日任务:设计本地数据库. 唐彬: 今日完成:请假.(编译+计组,压力有点大) 明日任务:阅读ios客户端代码. 史烨轩: 今日完成:请假 ...

  5. 【Alpha】阶段第九次Scrum Meeting

    [Alpha]阶段第九次Scrum Meeting 工作情况 团队成员 今日已完成任务 明日待完成任务 刘峻辰 编写获得所有学院接口 登出接口 赵智源 编写alpha版后测试点测试用例 编写脚本实现测 ...

  6. [2019BUAA软工]第0次代码作业

    Visual Studio 单元测试的简单应用 写在前面   笔者根据作业的介绍以及Visual Studio 2017 文档的相关说明,进行了Visual Studio 单元测试的简单应用. Tip ...

  7. 第二阶段Sprint1

    昨天:进行第二阶段第一次站立会议,讨论冲刺阶段,目标,任务认领 今天:实现视频录制,共享平台的视频下载和上传 遇到的问题:调手机摄像头没问题,共享平台怎么办

  8. 项目冲刺Beta第一篇博客

    Beta版本冲刺计划安排 1.当天站立式会议照片: 2.工作分工: 团队成员 分工 张洪滨060  排行榜界面美化 陈敬轩059  注册成功界面美化 黄兴067  登录界面美化 林国梽068  答题界 ...

  9. RabbitMQ使用笔记

    一.安装 1.下载所需安装包 下载服务端(原因在于RabbitMQ服务端代码是使用并发式语言erlang编写的):http://www.rabbitmq.com/install-windows.htm ...

  10. elicpse

    摘自http://blog.csdn.net/bug_love/article/details/72636505 eclipse error pages打红X的解决方法 我每次建一个Maven项目转为 ...