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 ...
随机推荐
- Collections库使用
Date: 2019-05-27 Author: Sun Collections库 Python拥有一些内置的数据类型,比如str, int, list, tuple, dict等, collec ...
- CentOS 7在grub rescue模式中修复系统
安装完CentOS 7后 修改硬盘分区后,系统重启后,无法正常启动,进入grub rescue模式: 网上大多数centos grub rescue的资料应该是Centos 7之前的,其中提到的命令很 ...
- Artisan 命令
php artisan key:generate 生成 App Key php artisan make:controller 生成控制器 php artisan make:model 生成模型 ph ...
- bootstrap 因跳页黑色背景无法关闭
只需要在跳页之前加上如下代码: $(".modal-backdrop").remove();
- 【BZOJ 1406】 [AHOI2007]密码箱
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] \(x^2%n=1\) \(x^2-1 = k*n\) \((x+1)*(x-1) % n == 0\) 设\(n=a*b\) 对于 ...
- Qt之QStackedLayout
简述 QStackedLayout继承自QLayout. QStackedLayout类提供了多页面切换的布局,一次只能看到一个界面. QStackedLayout可用于创建类似于QTabWidget ...
- [Typescript] Build Method decorators in Typescript
To using decorate, we can modifiy tsconfig.json: { "compilerOptions": { ... "experime ...
- hdu 2037 贪心
今年暑假不AC Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Su ...
- 走进windows编程的世界-----消息处理函数(2)
一 WM_PAINT消息 1 WM_PAINT的产生 因为窗体的互相覆盖等,产生须要绘制的区域,那么会产生WM_PAINT消息. 普通情况下,不直接发送WM_PAINT消息,通过API声明须要 ...
- Unity 内置Shader变量、辅助函数等
一:标准库里的常用.cginc文件 HLSLSupport.cginc - (automatically included) Helper macros and definitions for cro ...