QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#797821#9806. Growing TreeAiriSWA 11ms3928kbC++142.7kb2024-12-03 19:16:082024-12-03 19:16:08

Judging History

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

  • [2024-12-03 19:16:08]
  • 评测
  • 测评结果:WA
  • 用时:11ms
  • 内存:3928kb
  • [2024-12-03 19:16:08]
  • 提交

answer

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<map>
#include<vector>
using namespace std;
const int N=4100;
int n,len,a[N],vis[N],cut[N],cnt;
long long deep[N];
map<long long,int > id;
vector<int> sta[N];
#define fa(u) (((u+1)>>1)-1)
bool check1(int u,int v){
    while(u!=v){
        if(cut[v])return 1;
        u=fa(u);
        v=fa(v);
    }
    return 0;
}
bool check2(int u,int v){
    while(u!=v){
        if(cut[u])return 1;
        u=fa(u);
        v=fa(v);
    }
    return 0;
}
int dfs(int u,int nowans){
   // cerr<<u<<' '<<nowans<<'\n';
    if(u==len-(1<<n)){
        return nowans;
    }
    int uid=id[deep[u]];
   
    while(sta[uid].size()&&check1(u,sta[uid].back())){
        sta[uid].pop_back();
    }

    if(!sta[uid].size()){
        sta[uid].push_back(u);
        return dfs(u-1,nowans);
    }

    int v=sta[uid].back();
    if(check2(u,v)){
        sta[uid].push_back(u);
        return dfs(u-1,nowans);
    }

    int uu=u,vv=v;
    vector<pair<int,int>> vec;
    while(uu!=vv){
        vec.push_back(make_pair(uu,vv));
        uu=fa(uu);vv=fa(vv);
    }
    for(int i=vec.size()-1;i>=0;i--)
        if(!vis[i]){
            int ans=-1;
            {
                vis[i]=1;
                vector<int> p[cnt+1];
                for(int j=1;j<=cnt;j++)p[j]=sta[j];
                sta[uid].push_back(u);
                cut[vec[i].first]=1;
                ans=dfs(u-1,nowans+1);
                
                cut[vec[i].first]=0;
                vis[i]=0;
                for(int j=1;j<=cnt;j++)sta[j]=p[j];
            }

            {
                vis[i]=1;
                vector<int> p[cnt+1];
                for(int j=1;j<=cnt;j++)p[j]=sta[j];
                sta[uid].pop_back();
                sta[uid].push_back(u);
                cut[vec[i].second]=1;
                int now=dfs(u-1,nowans+1);
                if(ans==-1)ans=now;
                else if(now!=-1)ans=min(ans,now);

                cut[vec[i].second]=0;
                vis[i]=0;
                for(int j=1;j<=cnt;j++)sta[j]=p[j];
            }

            return ans;
        }
    
    return -1;
}
int main(){
    int T;scanf("%d",&T);
    while(T--){
        id.clear();cnt=0;
        scanf("%d",&n);
        len=(1<<(n+1))-2;
        for(int i=1;i<=len;i++)   
            scanf("%d",&a[i]);
        for(int i=1;i<=len;i++)
            deep[i]=deep[((i+1)>>1)-1]+a[i];
        for(int i=len-(1<<n)+1;i<=len;i++)if(!id[deep[i]])id[deep[i]]=++cnt;
        cout<<dfs(len,0)<<'\n';
        for(int i=0;i<=n;i++)vis[i]=0;
        for(int i=1;i<=cnt;i++)sta[i].clear();
    }    
    return 0;
}

详细

Test #1:

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

input:

3
2
1 2 4 3 2 1
2
1 2 3 3 2 1
2
1 2 3 3 1 1

output:

1
2
-1

result:

ok 3 number(s): "1 2 -1"

Test #2:

score: -100
Wrong Answer
time: 11ms
memory: 3928kb

input:

94
5
44 65 38 61 64 94 71 53 65 10 24 36 98 74 11 4 5 46 72 34 9 24 37 32 76 29 48 88 17 14 36 4 22 6 71 53 24 61 89 79 39 57 99 61 27 85 99 46 81 75 90 25 16 13 1 87 55 81 56 78 67 2
3
83 3 74 14 45 17 22 41 62 74 25 1 56 22
7
21 73 83 99 3 91 16 53 8 10 49 29 54 81 45 10 12 68 32 9 30 11 99 85 73 ...

output:

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

result:

wrong answer 35th numbers differ - expected: '3', found: '4'