线段树区间合并LCIShdu3308

#include<bits/stdc++.h>
using namespace std;
#define N 100100
int a[N];
struct {
    int left,right,c;
    int ln,rn;
    int ls,rs,ms;
}b[N*4];
void pushup(int i){
    b[i].ls=b[i*2].ls; b[i].rs=b[2*i+1].rs;
    b[i].ln=b[i*2].ln; b[i].rn=b[2*i+1].rn;
    b[i].ms=max(b[2*i].ms,b[2*i+1].ms);
    if(b[2*i].rn<b[2*i+1].ln){
        if(b[2*i].ls == b[2*i].c) b[i].ls+=b[2*i+1].ls;
        if(b[2*i+1].ls == b[2*i+1].c) b[i].rs+=b[2*i].rs;
        b[i].ms=max(b[i].ms,b[2*i+1].ls+b[i*2].rs);
    }
}
void build(int left,int right,int i){
    int mid;
    b[i].left=left;b[i].right=right;b[i].c=right-left+1;
    if(left==right) {
        b[i].ln=b[i].rn=a[left];
        b[i].ls=b[i].rs=b[i].ms=1;
        return ;
    }
    mid = (left+right)/2;
    build(left,mid,2*i);
    build(mid+1,right,2*i+1);
    pushup(i);
}
void Insert(int i,int t,int m){
    if(b[i].left==b[i].right){
        b[i].ln=b[i].rn=m;
        return ;
    }
    int mid=(b[i].left+b[i].right)>>1;
    if(t<=mid) Insert(2*i,t,m);
    if(t>mid) Insert(2*i+1,t,m);
    pushup(i);
}
int Query(int l,int r,int i){
    if(b[i].left>=l && b[i].right<=r) return b[i].ms;
    int mid=(b[i].right+b[i].left)>>1,ans=0;
    if(l<=mid) ans=max(ans,Query(l,r,2*i));
    if(r>mid) ans=max(ans,Query(l,r,2*i+1));
    if(b[2*i].rn<b[2*i+1].ln) ans = max(ans , min(mid-l+1,b[2*i].rs)+min(r-mid,b[2*i+1].ls));
        return ans;
}
int main(){
    int t;
    scanf("%d",&t);
    while(t--){

        memset(b,0,sizeof(b));
        int n,m;
        scanf("%d%d",&n,&m);
        for(int i=1;i<=n;i++) scanf("%d",&a[i]);
        build(1,n,1);
        while(m--){
            char q[10];
            int x,y;
            getchar();
            scanf("%s%d%d",q,&x,&y);
            if(q[0]=='U') Insert(1,x+1,y);
            else printf("%d\n",Query(x+1,y+1,1));
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值