QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#749408 | #9570. Binary Tree | rdcamelot | RE | 1ms | 3660kb | C++20 | 3.9kb | 2024-11-15 00:25:35 | 2024-11-15 00:25:35 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
using i64=long long;
using u64=unsigned long long;
#define ll long long
const int inf=1e9;
const ll inff=1e18;
using i128=__int128;
void solve(){
int n;
cin>>n;
vector<vector<int>> adj(n+1);
for(int i=0;i<n;i++){
int x,y;
cin>>x>>y;
if(x){
adj[i+1].emplace_back(x);
adj[x].emplace_back(i+1);
}
if(y){
adj[i+1].emplace_back(y);
adj[y].emplace_back(i+1);
}
}
vector<int> siz(n+1);
vector<int> w(n+1);
vector<int> vis(n+1);
int sum=n;
int ct=-1; //centroid
auto dfs=[&](auto self,int u,int p)->void{
siz[u]=1;
for(int v:adj[u]){
if(v==p) continue;
self(self,v,u);
siz[u]+=siz[v];
}
};
auto get=[&](auto self,int u,int p)->void{
siz[u]=1;
w[u]=0;
for(int v:adj[u]){
if(v==p || vis[v]) continue;
self(self,v,u);
siz[u]+=siz[v];
w[u]=max(w[u],siz[v]);
}
w[u]=max(w[u],sum-siz[u]);
if(w[u]<=sum/2){
ct=u;
}
};
get(get,1,0);
auto ask=[&](auto self,int u)->void{
dfs(dfs,u,0);
if(siz[u]==1){
cout<<"! "<<u<<'\n';
cout.flush();
return;
}
int v1=0,v2=0,v3=0;
for(int v:adj[u]){
if(vis[v]){
continue;
}
if(!v1){
v1=v;
}else if(!v2){
v2=v;
}else{
v3=v;
}
}
if(v3){
if(siz[v1]==min({siz[v1],siz[v2],siz[v3]})){
swap(v1,v3);
}
if(siz[v2]==min({siz[v1],siz[v2],siz[v3]})){
swap(v2,v3);
}
cout<<"? "<<v1<<' '<<v2<<'\n';
cout.flush();
int x;
cin>>x;
if(x==0){
int v=v1;
vis[u]=1;
sum=siz[v];
get(get,v,u);
self(self,ct);
return;
}
if(x==1){
vis[v1]=vis[v2]=1;
int v=u;
sum=siz[v3]+1;
get(get,u,v1);
self(self,ct);
return;
}
if(x==2){
int v=v2;
vis[u]=1;
sum=siz[v];
get(get,v,u);
self(self,ct);
return;
}
}
if(v2){
cout<<"? "<<v1<<' '<<v2<<'\n';
cout.flush();
int x;
cin>>x;
if(x==0){
int v=v1;
vis[u]=1;
sum=siz[v];
get(get,v,u);
self(self,ct);
return;
}
if(x==1){
cout<<"! "<<u<<'\n';
cout.flush();
return;
}
if(x==2){
int v=v2;
vis[u]=1;
sum=siz[v];
get(get,v,u);
self(self,ct);
return;
}
}
if(v1){
cout<<"? "<<v1<<' '<<u<<'\n';
cout.flush();
int x;
cin>>x;
if(x==0){
cout<<"! "<<v1<<'\n';
cout.flush();
return;
}
if(x==2){
cout<<"! "<<u<<'\n';
cout.flush();
return;
}
}
};
ask(ask,ct);
}
int main(){
ios::sync_with_stdio(0);cin.tie(0);
int t=1;
cin>>t;
while(t--){
solve();
}
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 1ms
memory: 3660kb
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 2 2 2 8 0 0 1 4 2 0 0 0 7 8 0 0 3 0 6 0 2 2 2 8 5 8 0 0 1 7 0 0 0 0 4 2 0 0 6 0 2 1 0 5 4 5 3 1 0 0 0 0 0 0 0 0 8 0 0 0 0 5 6 0 0 1 4 2 0 3 8 0 0 1 0 0
output:
? 6 8 ? 5 4 ? 3 4 ! 4 ? 2 7 ? 7 8 ? 6 8 ! 8 ? 3 8 ? 8 4 ? 2 6 ! 2 ? 2 4 ? 3 2 ! 3 ? 5 7 ? 3 2 ? 3 2 ? 3 2