QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#580691#9373. Query on TreeAfterlifeML 0ms26140kbC++208.1kb2024-09-21 23:09:322024-09-21 23:09:38

Judging History

你现在查看的是最新测评结果

  • [2024-09-21 23:09:38]
  • 评测
  • 测评结果:ML
  • 用时:0ms
  • 内存:26140kb
  • [2024-09-21 23:09:32]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;

#define int long long

const int N=2e5+1e3+7,K=10,INF=1e18;

struct T {
    vector<int> _;

    int cnt;

    struct Node {
        int l,r,ls,rs,tag,mx,sum;
    }t[N*2+1];

    void Add(int x,int v)
    {
        t[x].tag+=v;
        t[x].mx+=v;
        t[x].sum+=v;
    }

    void update(int x)
    {
        t[x].mx=max(t[t[x].ls].mx,t[t[x].rs].mx);
        t[x].sum=t[t[x].ls].sum+t[t[x].rs].sum;
    }

    void pushdown(int x)
    {
        if(t[x].tag)
        {
            Add(t[x].ls,t[x].tag);
            Add(t[x].rs,t[x].tag);
            t[x].tag=0;
        }
    }

    int build(int l,int r,vector<int> &a)
    {
        int x=++cnt;
        t[x].l=l,t[x].r=r;
        t[x].tag=0;
        if(l==r)
        {
            t[x].mx=a[l];
            t[x].sum=0;
            return x;
        }
        int mid=(l+r)>>1;
        t[x].ls=build(l,mid,a);
        t[x].rs=build(mid+1,r,a);
        update(x);
        return x;
    }

    void init(int n,vector<int> a) 
    {
        cnt=0;
        build(1,n,a);
    }

    void change(int x,int l,int r,int v)
    {
        if(l<=t[x].l&&t[x].r<=r)
        {
            Add(x,v);
            return;
        }
        int mid=(t[x].l+t[x].r)>>1;
        pushdown(x);
        if(l<=mid)
            change(t[x].ls,l,r,v);
        if(r>mid)
            change(t[x].rs,l,r,v);
        update(x);
    }

    int qsum(int x,int p)
    {
        if(t[x].l==t[x].r)
            return t[x].sum;
        int mid=(t[x].l+t[x].r)>>1;
        pushdown(x);
        if(p<=mid)
            return qsum(t[x].ls,p);
        else
            return qsum(t[x].rs,p);
    }

    void setv(int x,int p,int v)
    {
        if(t[x].l==t[x].r)
        {
            t[x].sum=0;
            t[x].mx=v;
            return;
        }
        int mid=(t[x].l+t[x].r)>>1;
        pushdown(x);
        if(p<=mid)
            setv(t[x].ls,p,v);
        else
            setv(t[x].rs,p,v);
    }

    int qmx(int x,int l,int r)
    {
        if(l<=t[x].l&&t[x].r<=r)
            return t[x].mx;
        pushdown(x);
        int mid=(t[x].l+t[x].r)>>1;
        int ret=LLONG_MIN;
        if(l<=mid)
            ret=max(ret,qmx(t[x].ls,l,r));
        if(r>mid)
            ret=max(ret,qmx(t[x].rs,l,r));
        return ret;
    }
}A,B;

int T;

int n,q,a[N],bc,dc;

int bfn[N],dfn[N],ds[N],bs[N],fa[N];

int lp[N][K+1],rp[N][K+1];

int mk[N][K+1],jmp[N][K+1],dep[N],st[N],ed[N];

vector<int> g[N];

signed main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cin>>T;
    while(T--)
    {
        cin>>n>>q;
        for(int i=1;i<=n;i++)
            cin>>a[i],g[i].clear();
        for(int i=1;i<n;i++)
        {
            int u,v;
            cin>>u>>v;
            g[u].push_back(v);
            g[v].push_back(u);
        }
        {
            bc=0;
            for(int i=1;i<=n;i++)
                bfn[i]=0;
            queue<int> q;
            q.push(1);
            while(!q.empty())
            {
                int x=q.front();
                q.pop();
                bfn[x]=++bc;
                bs[bc]=x;
                for(auto v:g[x])
                {
                    if(v==fa[x])
                        continue;
                    fa[v]=x;
                    dep[v]=dep[x]+1;
                    q.push(v);
                }
            }
        }
        {
            auto dfs=[&](auto self,int x,int f) ->void
            {
                dfn[x]=++dc;
                ds[dc]=x;
                st[x]=dc;
                for(auto v:g[x])
                {
                    if(v==f)
                        continue;
                    self(self,v,x);
                }
                ed[x]=dc;
            };

            dfs(dfs,1,0);
        }
        for(int i=n;i>=1;i--)
        {
            int x=bs[i];
            for(int j=1;j<=K;j++)
                lp[x][j]=n+1,rp[x][j]=0,mk[x][0]=-INF;
            lp[x][0]=rp[x][0]=i;
            mk[x][0]=a[x];
            for(auto v:g[x])
            {
                if(v==fa[x])
                    continue;
                for(int j=1;j<=K;j++)
                {
                    lp[x][j]=min(lp[x][j],lp[v][j-1]);
                    rp[x][j]=max(rp[x][j],rp[v][j-1]);
                    mk[x][j]=max(mk[x][j],mk[v][j-1]);
                }
            }
        }
        for(int i=1;i<=n;i++)
        {
            int x=bs[i];
            jmp[x][0]=x;
            jmp[x][1]=fa[x];
            for(int j=2;j<=K;j++)
                jmp[x][j]=jmp[jmp[x][j-1]][1];
        }
        vector<int> tmp(n+1);
        for(int i=1;i<=n;i++)
            tmp[i]=a[bs[i]];
        A.build(1,n,tmp);
        for(int i=1;i<=n;i++)
            tmp[i]=mk[ds[i]][K];
        B.build(1,n,tmp);
        auto push=[&](const int &x)
        {
            if(!x)
                return;
            if(lp[x][K]<=rp[x][K])
            {
                int t=B.qsum(1,dfn[x]);  
                A.change(1,lp[x][K],rp[x][K],t);
                B.setv(1,dfn[x],A.qmx(1,lp[x][K],rp[x][K]));
            }
        };
        while(q--)
        {
            int op;
            cin>>op;
            int ans=LLONG_MIN;
            if(op==1)
            {
                int x,d,v;
                cin>>x>>d>>v;
                {
                    int L=lp[x][d],R=rp[x][d];
                    push(jmp[x][K-d]);
                    if(L<=R)
                    {
                        A.change(1,L,R,v);
                        ans=max(ans,A.qmx(1,L,R));
                    }
                }
                for(int u=fa[x],z=u;u;z=u,u=fa[u])
                {
                    int rd=d-(dep[x]-dep[u]);
                    if(rd<0)
                        break;
                    int L=lp[u][rd],R=rp[u][rd];
                    push(jmp[u][K-rd]);
                    if(!rd)
                    {
                        if(L<=R)
                            A.change(1,L,R,v),ans=max(ans,A.qmx(1,L,R));
                    }
                    else
                    {
                        int lu=lp[z][rd-1],ru=rp[z][rd-1];
                        if(L<=lu-1)
                            A.change(1,L,lu-1,v),ans=max(ans,A.qmx(1,L,lu-1));
                        if(ru+1<=R)
                            A.change(1,ru+1,R,v),ans=max(ans,A.qmx(1,ru+1,R));
                    }
                }
            }
            else if(op==2)
            {
                vector<int>L(K*2+5,n+1),R(K*2+5,0);
                int S=K+1;
                int x,d,v;
                cin>>x>>d>>v;
                for(int u=x;u;u=fa[u])
                {
                    int rd=d-(dep[x]-dep[u]);
                    if(rd<0)
                        break;
                    for(int j=0;j<=rd;j++)
                    {
                        L[dep[u]+j-dep[x]+S]=min(L[dep[u]+j-dep[x]+S],lp[u][j]);
                        R[dep[u]+j-dep[x]+S]=max(R[dep[u]+j-dep[x]+S],rp[u][j]);
                    }
                }
                for(int j=0;j<L.size();j++)
                {
                    if(L[j]>R[j])
                        continue;
                    int u=bs[L[j]];
                    push(jmp[u][K]);
                    A.change(1,L[j],R[j],v);
                    ans=max(ans,A.qmx(1,L[j],R[j]));
                }
            }
            else if(op==3)
            {
                int x,v;
                cin>>x>>v;
                for(int j=0;j<K;j++)
                {
                    int u=jmp[x][K-j];
                    push(u);
                    if(lp[x][j]<=rp[x][j])
                    {
                        A.change(1,lp[x][j],rp[x][j],v);
                        ans=max(ans,A.qmx(1,lp[x][j],rp[x][j]));
                    }
                }
                B.change(1,st[x],ed[x],v);
                ans=max(ans,B.qmx(1,st[x],ed[x]));
            }
            if(ans<-1e15)
                cout<<"GG\n";
            else
                cout<<ans<<"\n";
        }
    }
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 26140kb

input:

1
5 5
1 2 1 3 2
1 2
2 3
2 4
4 5
2 2 1 0
1 2 1 3
3 4 -5
2 5 2 3
3 2 -1

output:

3
6
1
5
4

result:

ok 5 lines

Test #2:

score: -100
Memory Limit Exceeded

input:

10000
3 9
42973045452542 34994498886390 -91733395797555
1 3
1 2
1 1 5 -71952967
3 1 -816873082
1 1 5 -842437577
2 3 7 254550528
3 3 -854082700
2 3 2 699808309
3 3 554885567
1 2 7 595565507
1 3 0 -318374053
3 2
-63158159333100 77264362049163 -99188430131116
1 2
3 2
2 2 4 -305866230
3 1 -549738403
3 5...

output:


result: