5种操作

具体看代码

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std; #define lson u<<1
#define rson u<<1|1
#define MAXN 100010 int dat[MAXN]; struct Node {
int lef,rig;
int lsum,rsum,msum;//左端最长连续1,右端最长连续1,区间最长连续1
int lz,rz,mz;//左端最长连续0,右端最长连续0,区间最长连续0
int sum;//区间1的个数
int COVER,XOR;
}T[MAXN<<]; void makeXOR(int u){//翻转操作
swap(T[u].lsum,T[u].lz);
swap(T[u].rsum,T[u].rz);
swap(T[u].msum,T[u].mz);
T[u].sum=T[u].rig-T[u].lef+-T[u].sum;
} void PushUp(int u){
if(T[u].lef==T[u].rig)return;
int len=T[u].rig-T[u].lef+;
T[u].lsum=T[lson].lsum;
T[u].rsum=T[rson].rsum;
if(T[u].lsum==(len+)>>)T[u].lsum+=T[rson].lsum;
if(T[u].rsum==len>>)T[u].rsum+=T[lson].rsum;
T[u].msum=max(T[lson].msum,T[rson].msum);
T[u].msum=max(T[u].msum,T[lson].rsum+T[rson].lsum); T[u].lz=T[lson].lz;
T[u].rz=T[rson].rz;
if(T[u].lz==(len+)>>)T[u].lz+=T[rson].lz;
if(T[u].rz==len>>)T[u].rz+=T[lson].rz;
T[u].mz=max(T[lson].mz,T[rson].mz);
T[u].mz=max(T[u].mz,T[lson].rz+T[rson].lz); T[u].sum=T[lson].sum+T[rson].sum;
} void PushDown(int u){
if(T[u].lef==T[u].rig)return;
if(T[u].COVER!=-){
int len=T[u].rig-T[u].lef+;
T[lson].COVER=T[rson].COVER=T[u].COVER;
T[lson].XOR=T[rson].XOR=;
T[lson].lsum=T[lson].rsum=T[lson].msum=T[u].COVER?(len+)>>:;
T[lson].lz=T[lson].rz=T[lson].mz=T[u].COVER?:(len+)>>;
T[lson].sum=T[u].COVER?(len+)>>:; T[rson].lsum=T[rson].rsum=T[rson].msum=T[u].COVER?len>>:;
T[rson].lz=T[rson].rz=T[rson].mz=T[u].COVER?:len>>;
T[rson].sum=T[u].COVER?len>>:; T[u].COVER=-;
}
if(T[u].XOR){
T[u].XOR=;
T[lson].XOR^=;
T[rson].XOR^=;
makeXOR(lson);
makeXOR(rson);
}
} void Build(int u,int l,int r){
T[u].lef=l;
T[u].rig=r;
T[u].COVER=-;
T[u].XOR=;
if(l==r){
T[u].lsum=T[u].rsum=T[u].msum=(dat[l]==);
T[u].lz=T[u].rz=T[u].mz=(dat[l]==);
T[u].sum=dat[l];
T[u].COVER=dat[l];
return;
}
int mid=(l+r)>>;
Build(lson,l,mid);
Build(rson,mid+,r);
PushUp(u);
} void Update(int u,int l,int r,int op){
PushDown(u);//这里应该先pushdown
if(l<=T[u].lef&&T[u].rig<=r){
if(op<){//覆盖操作
int len=T[u].rig-T[u].lef+;
T[u].COVER=op;
T[u].lsum=T[u].rsum=T[u].msum=op?len:;
T[u].lz=T[u].rz=T[u].mz=op?:len;
T[u].sum=op?len:;
}
else {
T[u].XOR=;
makeXOR(u);
}
}
else {
if(l<=T[lson].rig)Update(lson,l,r,op);
if(r>=T[rson].lef)Update(rson,l,r,op);
PushUp(u);
}
} int Query(int u,int l,int r,int op){
PushDown(u);//应该先 pushdown,以防错误
if(l<=T[u].lef&&T[u].rig<=r){
if(op==)return T[u].sum;
else return T[u].msum;
}
else {
if(r<=T[lson].rig)return Query(lson,l,r,op);
if(l>=T[rson].lef)return Query(rson,l,r,op);
if(op==) return Query(lson,l,T[lson].rig,op)+Query(rson,T[rson].lef,r,op); int ret=min(T[lson].rsum,T[lson].rig-l+)+min(T[rson].lsum,r-T[rson].lef+);
int ans=max(Query(lson,l,T[lson].rig,op),Query(rson,T[rson].lef,r,op));
return max(ans,ret); }
} int main(){ int t;
scanf("%d",&t);
while(t--){
int n,m;
int cmd,a,b; scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)scanf("%d",dat+i);
Build(,,n); while(m--){
scanf("%d%d%d",&cmd,&a,&b);
a++,b++;
if(cmd<)Update(,a,b,cmd);
else printf("%d\n",Query(,a,b,cmd));
}
}
return ;
}

线段树 HDU 3397的更多相关文章

  1. 线段树 HDU 3397(真)

    5 种操作  0 1 然后 异或 似乎这种2个更新的先后每次都搞不清 覆盖有覆盖就可以不异或 也不知道为什么 #include<stdio.h> #include<string.h& ...

  2. 主席树[可持久化线段树](hdu 2665 Kth number、SP 10628 Count on a tree、ZOJ 2112 Dynamic Rankings、codeforces 813E Army Creation、codeforces960F:Pathwalks )

    在今天三黑(恶意评分刷上去的那种)两紫的智推中,突然出现了P3834 [模板]可持久化线段树 1(主席树)就突然有了不详的预感2333 果然...然后我gg了!被大佬虐了! hdu 2665 Kth ...

  3. 最大矩阵覆盖权值--(静态连续最大子段 (线段树) )-HDU(6638)Snowy Smile

    这题是杭电多校2019第六场的题目 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6638 题意:给你平面上n个点,每个点都有权值(有负权),让你计算一 ...

  4. 敌兵布阵(线段树HDU 1166)

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submissi ...

  5. HDU 6464 权值线段树 && HDU 6468 思维题

    免费送气球 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submi ...

  6. 区间第k大问题 权值线段树 hdu 5249

    先说下权值线段树的概念吧 权值平均树 就是指区间维护值为这个区间内点出现次数和的线段树 用这个加权线段树 解决第k大问题就很方便了 int query(int l,int r,int rt,int k ...

  7. 线段树 HDU 3308

    t 题目大意:给你n个数,m个操作.操作有两种:1.U x y 将数组第x位变为y   2. Q x y 问数组第x位到第y位连续最长子序列的长度.对于每次询问,输出一个答案 #include< ...

  8. 二维线段树 HDU 1823最简单的入门题

    xiaoz 征婚,首先输入M,表示有M个操作. 借下来M行,对每一行   Ih a l     I 表示有一个MM报名,H是高度, a是活泼度,L是缘分. 或   Q h1 h2 a1 a2    求 ...

  9. bzoj 3038: 上帝造题的七分钟2 线段树||hdu 4027

    3038: 上帝造题的七分钟2 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 1066  Solved: 476[Submit][Status][Dis ...

随机推荐

  1. iOS开发之功能模块--模糊效果

    1.先介绍一个好用的实现模糊效果的框架:https://github.com/YouXianMing/UIImageBlur 2.iOS8 中 UIVisualEffectView 模糊效果的使用 , ...

  2. IOS 多线程分类以及多线程的相关操作

    直接附上援助链接:http://www.cnblogs.com/kenshincui/p/3983982.html 分享内容还关联到了生产者与消费者模式(其实看明白了整片文章,也就理解了生产者与消费者 ...

  3. Spring 中classPath:用法

    参考文章地址: http://hi.baidu.com/huahua035/item/ac8a27a994b55bad29ce9d39 http://blog.csdn.net/lushuaiyin/ ...

  4. MongoDB安装及配置成服务

    最近接收了个新项目,这个项目用到了很多之前没用过的(MongoDB.Redis.MVC5+EF6 等等),以前只是看过别人用,自己从未尝试,唯独用了MVC2+EF4,可能是我落伍了,不扯了,进入正题. ...

  5. Linux AVG ANTIVIRUS FREE使用介绍

    杀毒软件AVG,没有用过估计也有所耳闻.AVG ANTIVIRUS FREE - FOR LINUX 是AVG在Linux下的一款免费杀毒软件.它的官方下载地址供了rpm.deb.源码安装包等多种安装 ...

  6. SQL Server 2008 R2 升级到 Service Pack 3后Report Builder启动不了

    一同事将测试服务器从SQL Server 2008 R2 SP2升级到了SQL Server 2008 R2 SP3后发现Report Service的报表编辑时启动不了Report Builder, ...

  7. MS SQL 监控错误日志的告警信息

    SQL Server的错误消息(Error Message)按照消息的严重级别一共划分25个等级,级别越高,表示严重性也越高.但是如果你统计sys.messages,你会发现,实际上只有16(SQL ...

  8. Topshelf 创建windows服务注意事项

    其中项目应该是控制台应用程序 test.exe需要赋与管理员权限,右键属性可以定义. test.exe  install test.exe unstall

  9. java弱引用之WeakHashMap相关资料

    本人博客中有一篇文章对java中的引用有详细的介绍[http://www.cnblogs.com/javaee6/p/4763190.html],java中WeakHashMap这个类就是java弱引 ...

  10. 编码中的setCharacterEncoding 理解

    1.pageEncoding="UTF-8"的作用是设置JSP编译成Servlet时使用的编码.  2.contentType="text/html;charset=UT ...