QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#744545#9570. Binary TreeawayyyRE 1ms3632kbC++202.5kb2024-11-13 22:21:132024-11-13 22:21:14

Judging History

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

  • [2024-11-13 22:21:14]
  • 评测
  • 测评结果:RE
  • 用时:1ms
  • 内存:3632kb
  • [2024-11-13 22:21:13]
  • 提交

answer

#include<bits/stdc++.h>
#define int long long
using namespace std;
using ll = long long;
using ld = double;
const ll mod = 1e9 + 7;
const ll inf = 1e18 + 5;
const int N = 1e6 + 5;
vector<vector<int> >ed;	//存边
vector<int>siz,mxsiz,qans,vis;	//siz存每个以x为根的子树大小,mxsiz存每个x的儿子的最大子树
void init(int n){			//qans存重心
    siz=mxsiz=vector<int>(n+5);
    qans.clear();
}
void dfs(int x,int fa,int n){
    siz[x]=1;
    mxsiz[x]=0;
    for(auto son:ed[x]){
        if(son==fa||vis[son])continue;
        dfs(son,x,n);
        siz[x]+=siz[son];
        mxsiz[x]=max(mxsiz[x],siz[son]);
    }
    mxsiz[x]=max(mxsiz[x],n-siz[x]);
    if(mxsiz[x]<=n/2){
        qans.push_back(x);
    }
}
void solve(){
    int n;
    cin>>n;
    ed=vector<vector<int> >(n+5);
    vis=vector<int>(n+5);
    for(int i=1;i<=n;i++){
        int a,b;
        cin>>a>>b;
        if(a){
            ed[i].push_back(a);
            ed[a].push_back(i);
        }
        if(b){
            ed[i].push_back(b);
            ed[b].push_back(i);
        }
    }
    int n1=n,now=1;
    while(n1>2){
        init(n1);
        dfs(now,0,n1);
        int mx=0,pos=0,pos1=0;
        now=qans[0];
        init(n1);
        dfs(now,0,n1);
        for(auto son:ed[now]){
            if(mx<siz[son]){
                mx=siz[son];
                pos=son;
            }
        }
        for(auto son:ed[now]){
            if(pos!=son){
                pos1=son;
                break;
            }
        }
        cout<<"? "<<pos<<' '<<pos1<<endl;
        int op;
        cin>>op;
        if(op==0){
            vis[now]=1;
            now=pos;
            n1=siz[pos];
        }else if(op==1){
            vis[pos]=vis[pos1]=1;
            n1=n1-siz[pos]-siz[pos1];
        }else{
            vis[now]=1;
            now=pos1;
            n1=siz[pos1];
        }
    }
    if(n1==2){
        int pos=0;
        for(auto son:ed[now]){
            if(!vis[son]){
                pos=son;
                break;
            }
        }
        cout<<"? "<<pos<<' '<<now<<endl;
        int op;
        cin>>op;
        if(op==0){
            cout<<"! "<<pos<<endl;
        }else{
            cout<<"! "<<now<<endl;
        }
    }else{
        cout<<"! "<<now<<endl;
    }
}

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(0);cout.tie(0);
//    cout<<fixed<<setprecision(6);
//    srand(time(0));
    int T = 1;
    cin >> T;
    while (T--)solve();
    return 0;
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 3632kb

input:

2
5
0 0
1 5
2 4
0 0
0 0
1
0
2
0 2
0 0
2

output:

? 3 1
? 5 2
! 5
? 2 1
! 1

result:

ok OK (2 test cases)

Test #2:

score: -100
Runtime Error

input:

5555
8
2 0
8 6
0 0
3 0
0 0
7 0
0 0
5 4
0
0
2
8
0 0
1 4
2 0
0 0
7 8
0 0
3 0
6 0
0
1
0
8
5 8
0 0
1 7
0 0
0 0
4 2
0 0
6 0
0
0
2
5
4 5
3 1
0 0
0 0
0 0
0
2
8
0 0
0 0
5 6
0 0
1 4
2 0
3 8
0 0
0
1
0
5
3 0
5 1
0 0
0 0
4 0
0
0
5
5 0
0 0
0 0
3 0
2 4
1
0
3
3 0
1 0
0 0
2
2
2 0
0 0
2
3
2 3
0 0
0 0
2
10
2 8
9 7
0 ...

output:

? 2 5
? 2 7
? 1 2
! 2
? 3 5
? 1 4
? 3 2
! 3
? 1 6
? 1 7
? 5 1
! 1
? 2 4
? 3 2
! 2
? 5 6
? 1 3
? 4 5
! 4
? 5 1
? 4 5
! 4
? 4 1
? 2 5
! 2
? 3 2
! 2
? 2 1
! 1
? 2 3
! 3
? 2 6
? 1 9
? 10 9
! 9
? 2 1
! 1
? 5 9
? 4 8
? 5 3
! 5
? 5 8
? 7 1
? 9 7
! 7
? 9 3
? 1 7
? 9 2
! 9
? 2 1
! 2

result: