9pts线段树+求调+悬关+码风良好

P4513 小白逛公园

Autumn_Rain @ 2024-07-21 09:18:19

#include<bits/stdc++.h>
using namespace std;
const int N=5e5+10;
int n,m,a[N];
int op,x,y;
struct node{
    int sum,w;
    int lmx,rmx;
}t[4*N];
void pushup(int u){
    t[u].w=t[u*2].w+t[u*2+1].w;
    t[u].lmx=max(t[u*2].lmx,t[u*2].w+t[u*2+1].lmx);
    t[u].rmx=max(t[u*2+1].rmx,t[u*2+1].w+t[u*2].rmx);
    t[u].sum=max(t[u*2].sum,t[u*2+1].sum);
    t[u].sum=max(t[u].sum,t[u*2].sum+t[u*2+1].sum);
}
void build(int u,int l,int r){
    if(l==r){
        t[u].lmx=t[u].rmx=a[l];
        t[u].sum=t[u].w=a[l];
        return;
    }
    int mid=(l+r)>>1;
    build(u*2,l,mid);
    build(u*2+1,mid+1,r);
    pushup(u);
}
void upd(int u,int l,int r,int p,int x){
    if(l==r){
        t[u].lmx=t[u].rmx=x;
        t[u].sum=t[u].w=x;
        return;
    }
    int mid=(l+r)>>1;
    if(p<=mid)upd(u*2,l,mid,p,x);
    else upd(u*2+1,mid+1,r,p,x);
    pushup(u);
}
node qry(int u,int L,int R,int l,int r){
    if(l<=L&&R<=r)return t[u];
    int mid=(L+R)>>1;
    if(r<=mid)return qry(u*2,L,mid,l,r);
    else if(mid<l)return qry(u*2+1,mid+1,R,l,r);
    node t,t1,t2;
    t1=qry(u*2,L,mid,l,r);
    t2=qry(u*2+1,mid+1,R,l,r);
    t.lmx=max(t1.lmx,t1.w+t2.lmx);
    t.rmx=max(t2.rmx,t2.w+t1.rmx);
    t.sum=max(max(t1.sum,t2.sum),(t2.lmx+t1.rmx));
    return t;
}
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++){
        cin>>a[i];
    }
    build(1,1,n);
    while(m--){
        cin>>op>>x>>y;
        if(op==1){
            if(x>y)swap(x,y);
            cout<<qry(1,1,n,x,y).sum<<"\n";
        }
        else upd(1,1,n,x,y);
    }
    return 0;
} 

by 5t0_0r2 @ 2024-07-21 09:20:50

@Autumn_Rain 不开 long long 见祖宗


by Autumn_Rain @ 2024-07-21 09:26:51

@5t0_0r2 其实开了还是9分()


by Obijeb @ 2024-07-21 09:31:50

pushup()中:

t[u].sum=max(t[u].sum,t[u*2].sum+t[u*2+1].sum);

这句不对啊

两段不一定连续,不能直接相加的


by Obijeb @ 2024-07-21 09:32:09

@Autumn_Rain


by 幽竹烟雨 @ 2024-07-21 09:34:38

@Autumn_Rain

t[u].sum=max(t[u].sum,t[u*2].sum+t[u*2+1].sum);

改为

t[u].sum=max(t[u].sum,t[u*2].rmx+t[u*2+1].lmx);

by Autumn_Rain @ 2024-07-21 09:47:31

@幽竹烟雨 @Obijeb 谢谢,已关。


|