老是写挂:)

#include<bits/stdc++.h>

using namespace std;

using ll=long long ;


const int maxn=2e5+9;
struct Node{
    ll l,r,v,tag;
}tr[maxn<<2];

ll n,f,a[maxn];

void build(int l,int r,int tot){
    if(l==r){
        tr[tot].v=a[l];
        return ;
    }
    int mid=(l+r)>>1;
    build(l,mid,tot<<1),build(mid+1,r,(tot<<1)|1);
    tr[tot].v=tr[tot<<1].v+tr[(tot<<1)|1].v;
}

void update(int nl,int nr,int tot,int l,int r,ll x){
    int mid=(nl+nr)>>1;
    if(tr[tot].tag&&nl!=nr){
        tr[tot<<1].v+=tr[tot].tag*(mid-nl+1ll),tr[(tot<<1)|1].v+=tr[tot].tag*(nr-mid+0ll);
        tr[tot<<1].tag+=tr[tot].tag,tr[(tot<<1)|1].tag+=tr[tot].tag;
        tr[tot].tag=0;
    }
    if(l<=nl&&nr<=r){
        tr[tot].v+=(nr-nl+1ll)*x,tr[tot].tag+=x;
        return ;
    }
    if(mid>=l)update(nl,mid,tot<<1,l,r,x);
    if(mid<r)update(mid+1,nr,(tot<<1)|1,l,r,x);
    tr[tot].v=tr[tot<<1].v+tr[(tot<<1)|1].v;
}

ll query(int nl,int nr,int tot,int l,int r){
    ll mid=(nl+nr)>>1,res=0;
    if(tr[tot].tag&&nl!=nr){
        tr[tot<<1].v+=tr[tot].tag*(mid-nl+1ll),tr[(tot<<1)|1].v+=tr[tot].tag*(nr-mid+0ll);
        tr[tot<<1].tag+=tr[tot].tag,tr[(tot<<1)|1].tag+=tr[tot].tag;
        tr[tot].tag=0;
    }
    if(l<=nl&&nr<=r)return tr[tot].v;
    if(mid>=l)res+=query(nl,mid,tot<<1,l,r);
    if(mid<r)res+=query(mid+1,nr,(tot<<1)|1,l,r);
    return res;
}

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);
    cin>>n>>f;
    for(int i=1;i<=n;++i)cin>>a[i];
    build(1,n,1);
    for(int i=1,x,y,z,w;i<=f;++i){
        cin>>x;
        if(x==1){
            cin>>y>>z>>w;
            update(1,n,1,y,z,w);
        }else if(x==2){
            cin>>y;
            update(1,n,1,1,1,y);
        }else if(x==3){
            cin>>y;
            update(1,n,1,1,1,-y);
        }else if(x==4){
            cin>>y>>z;
            cout<<query(1,n,1,y,z)<<"\n";
        }else cout<<query(1,n,1,1,1)<<"\n";
    }
}
此文章已被阅读次数:正在加载...更新于