HDU 3911 线段树区间合并
北京赛区快了,准备袭击数据结构和图论。倒计时 18天,线段树区间合并。维护一个最长连续。。
题意:给一个01串,以下有一些操作,问区间最长的连续的1的个数
#include<iostream>
#include<cstdio>
#include<map>
#include<set>
#include<cmath>
#define lson id << 1
#define rson id << 1|1
using namespace std;
const int M = 1e6+8;
int a[M];
struct tree{
int l,r;
int rsum1,lsum1,msum1,lsum0,rsum0,msum0;
int flag;
int mid(){
return (l+r)/2;
}
}node[M];
void pushdown(int id){
if(node[id].flag){
node[lson].flag ^= 1;
node[rson].flag ^= 1;
node[id].flag = 0;
swap(node[lson].lsum1,node[lson].lsum0);
swap(node[lson].rsum1,node[lson].rsum0);
swap(node[lson].msum1,node[lson].msum0); swap(node[rson].lsum1,node[rson].lsum0);
swap(node[rson].rsum1,node[rson].rsum0);
swap(node[rson].msum1,node[rson].msum0);
}
}
void pushup(int id){
int ll = node[lson].r-node[lson].l + 1;
int rl = node[rson].r-node[rson].l + 1;
node[id].lsum1 = node[lson].lsum1;
if(node[lson].lsum1 == ll)node[id].lsum1 += node[rson].lsum1;
node[id].rsum1 = node[rson].rsum1;
if(node[rson].rsum1 == rl)node[id].rsum1 += node[lson].rsum1;
node[id].msum1 = max(max(node[rson].msum1,node[lson].msum1),node[lson].rsum1+node[rson].lsum1); node[id].lsum0 = node[lson].lsum0;
if(node[lson].lsum0 == ll)node[id].lsum0 += node[rson].lsum0;
node[id].rsum0 = node[rson].rsum0;
if(node[rson].rsum0 == rl)node[id].rsum0 += node[lson].rsum0;
node[id].msum0 = max(max(node[rson].msum0,node[lson].msum0),node[lson].rsum0+node[rson].lsum0); }
void build(int l,int r,int id){
node[id].l = l;
node[id].r = r;
node[id].flag = 0;
if(l == r){
if(a[l] == 1){
node[id].lsum1 = node[id].rsum1 = node[id].msum1 = 1;
node[id].lsum0 = node[id].rsum0 = node[id].msum0 = 0;
}else{
node[id].lsum1 = node[id].rsum1 = node[id].msum1 = 0;
node[id].lsum0 = node[id].rsum0 = node[id].msum0 = 1;
}
return;
}
int mid = node[id].mid();
build(l,mid,lson);
build(mid+1,r,rson);
pushup(id);
}
void update(int id,int l,int r){
if(node[id].l == l && node[id].r == r){
node[id].flag ^= 1;
swap(node[id].lsum1,node[id].lsum0);
swap(node[id].rsum1,node[id].rsum0);
swap(node[id].msum1,node[id].msum0);
return ;
}
pushdown(id);
int mid = node[id].mid();
if(r <= mid)update(lson,l,r);
else if(l>mid)update(rson,l,r);
else {
update(lson,l,mid);
update(rson,mid+1,r);
}
pushup(id);
}
int query(int id,int l,int r){
if(node[id].l == l && node[id].r ==r){
return node[id].msum1;
}
pushdown(id);
int mid = node[id].mid();
if(r <=mid)return query(lson,l,r);
else
if(l > mid)return query(rson,l,r);
else {
int ll = query(lson,l,mid);
int rr = query(rson,mid+1,r);
int a = node[lson].rsum1;
if(a > (node[lson].r - l +1))a = node[lson].r - l +1 ; int b = node[rson].lsum1;
if(b > (r - node[rson].l+1))b = r - node[rson].l+1;
return max(max(ll,rr),a+b);
} }
int main(){
int n,m,op,l,r;
while(~scanf("%d",&n)){
for(int i=1;i<=n;i++)scanf("%d",&a[i]);
build(1,n,1);
scanf("%d",&m);
while(m--){
scanf("%d%d%d",&op,&l,&r);
if(!op)printf("%d\n",query(1,l,r));
else update(1,l,r);
}
}
}
HDU 3911 线段树区间合并的更多相关文章
- HDU 3911 线段树区间合并、异或取反操作
题目:http://acm.hdu.edu.cn/showproblem.php?pid=3911 线段树区间合并的题目,解释一下代码中声明数组的作用: m1是区间内连续1的最长长度,m0是区间内连续 ...
- hdu 3308(线段树区间合并)
LCIS Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 1806(线段树区间合并)
Frequent values Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
- hdu 3308 线段树 区间合并+单点更新+区间查询
LCIS Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 3911 Black And White (线段树 区间合并)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3911 题意: 给你一段01序列,有两个操作: 1.区间异或,2.询问区间最长的连续的1得长度 思路: ...
- HDU 3911 Black And White(线段树区间合并+lazy操作)
开始以为是水题,结果...... 给你一些只有两种颜色的石头,0为白色,1为黑色. 然后两个操作: 1 l r 将[ l , r ]内的颜色取反 0 l r 计算[ l , r ]内最长连续黑色石头的 ...
- HDU 3308 LCIS (线段树区间合并)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3308 题目很好懂,就是单点更新,然后求区间的最长上升子序列. 线段树区间合并问题,注意合并的条件是a[ ...
- HDU 3308 (线段树区间合并)
http://acm.hdu.edu.cn/showproblem.php?pid=3308 题意: 两个操作 : 1 修改 单点 a 处的值. 2 求出 区间[a,b]内的最长上升子序列. 做法 ...
- HDU 6638 - Snowy Smile 线段树区间合并+暴力枚举
HDU 6638 - Snowy Smile 题意 给你\(n\)个点的坐标\((x,\ y)\)和对应的权值\(w\),让你找到一个矩形,使这个矩阵里面点的权值总和最大. 思路 先离散化纵坐标\(y ...
随机推荐
- http扩展请求头中的x-Forwarded-For
X-Forwarded-For格式: X-Forwarded-For: client-ip, proxy1-ip, proxy2-ip 客户端请求服务器的过程中没经过一个代理层(代理中使用了xff)那 ...
- 关于js里的document.compatmode
document.compatmode为获取页面的渲染模式. 其中有两个渲染模式 1.CSS1Compat(标准模式).浏览器宽度:document.documentElement.clientHei ...
- 关联对象 AssociatedObject 完全解析
我们在 iOS 开发中经常需要使用分类(Category),为已经存在的类添加属性的需求,但是使用 @property 并不能在分类中正确创建实例变量和存取方法. 不过,通过 Objective-C ...
- appium ios端自动化测试配置
一.安装环境介绍macOS 10.12.4 Xcode 8.3.2 适用机型:iOS9 及以上机型 二.Appium源码安装Xcode升级8.2之后不再支持UIAutomation,转而使用XCUIT ...
- NYIST 46 最少乘法次数
最少乘法次数 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 给你一个非零整数,让你求这个数的n次方,每次相乘的结果可以在后面使用,求至少需要多少次乘.如24:2*2 ...
- Multi-Byte Character Set & Unicode Character Set
本系列文章由 @YhL_Leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/49592361 编程时遇到BUG:err ...
- Camera Calibration 相机标定:Opencv应用方法
本系列文章由 @YhL_Leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/49427383 Opencv中Camer ...
- 关于bom ef+bb+bf的问题
今天在商品详细页头部出现了一行空白,各种尝试无果,最后怀疑是不是bom头的问题,经过断点跟踪调试逐步缩小范围,果然最后发现是一个语言包文件的开头有 ef bb bf样式的字节,用ultraedit另存 ...
- 埃及分数 迭代加深搜索 IDA*
迭代加深搜索 IDA* 首先枚举当前选择的分数个数上限maxd,进行迭代加深 之后进行估价,假设当前分数之和为a,目标分数为b,当前考虑分数为1/c,那么如果1/c×(maxd - d)< a ...
- 51nod-1189: 阶乘分数
[传送门:51nod-1189] 简要题意: 给出一个数n,求出有多少个正整数x,y(0<x<=y)满足$1/n!=1/x+1/y$ 题解: 一开始还以为不可做 结果推一下柿子就会了 $1 ...