QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#738262#9570. Binary TreeEMTzWA 0ms7660kbC++202.4kb2024-11-12 18:27:302024-11-12 18:27:31

Judging History

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

  • [2024-11-12 18:27:31]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:7660kb
  • [2024-11-12 18:27:30]
  • 提交

answer

#include <bits/stdc++.h>
#define int long long
#define lson k<<1
#define rson (k<<1)|1
#define debug cout<<666<<endl;
using namespace std;
const int N=1e6+5;
vector<int>E[N];
int siz[N];
int rt;
int ma[N];
int st[N];
int now=1;
bool cmp(int a,int b)
{
	return siz[a]>siz[b];
}
int cnt=0;
void dfs(int u,int fa,int tot)
{
	siz[u]=1;
	ma[u]=0;
	for(auto v:E[u])
	{
		if(v==fa||st[v]==1) continue;
		dfs(v,u,tot);
		siz[u]+=siz[v];
		ma[u]=max(ma[u],siz[v]);
	}
	ma[u]=max(ma[u],tot-siz[u]);
	if(ma[u]<ma[rt])
	{
		rt=u;
	}
}
void dfs1(int u,int fa)
{
	// cout<<u<<"\n";
	vector<int>a;
	st[u]=1;
	for(auto v:E[u])
	{
		if(v==fa||st[v]==1) continue;
		a.push_back(v);
	}
	if(a.size()==0) 
	{
		cout<<"! "<<u<<"\n";
		fflush(stdout);
	}
	if(a.size()==1)
	{
		
		cout<<"? "<<a[0]<<" "<<u<<"\n";
		fflush(stdout);
		cnt++;
		int t;
		cin>>t;
		if(t==0)
		{
			cout<<"! "<<a[0]<<"\n";
		}
		else cout<<"! "<<u<<"\n";
		fflush(stdout);
		
	}
	else if(a.size()==2)
	{
		cout<<"? "<<a[0]<<" "<<a[1]<<"\n";
		fflush(stdout);
		cnt++;
		int t;
		cin>>t;
		if(t==0)
		{
			rt=0;
			dfs(a[0],u,siz[a[0]]);
			dfs1(rt,u);
		}
		else if(t==1)
		{
			cout<<"! "<<u<<"\n";
			fflush(stdout);
		}
		else 
		{
			rt=0;
			dfs(a[1],u,siz[a[1]]);
			dfs1(rt,u);
		}
	}
	else if(a.size()==3)
	{
		// cout<<"&";
		sort(a.begin(),a.end(),cmp);
		cout<<"? "<<a[0]<<" "<<a[1]<<"\n";
		fflush(stdout);
		cnt++;
		
		int t;
		cin>>t;
		if(t==0)
		{
			rt=0;
			dfs(a[0],u,siz[a[0]]);
			dfs1(rt,u);
		}
		else if(t==1)
		{
			rt=0;
			st[u]=0;
			st[a[0]]=1;
			st[a[1]]=1;
			dfs(u,fa,siz[a[2]]+1);
			// cout<<rt<<"\n";
			dfs1(rt,u);
		}
		else 
		{
			rt=0;
			dfs(a[1],u,siz[a[1]]);
			dfs1(rt,u);
		} 
	}
	
}
void vision()
{
	now=0;
	ma[0]=1e9;
	int n;
	cin>>n;
	rt=0;
	for(int i=0;i<=n;i++)
	{
		E[i].clear();   
		st[i]=0;
	}
	for(int i=1;i<=n;i++)
	{
		int u,v;
		cin>>u>>v;
		if(u!=0)
		{
			E[i].push_back(u);
			E[u].push_back(i);
		}
		if(v!=0) 
		{
			E[i].push_back(v);
			E[v].push_back(i);
		}
	}
	dfs(1,0,n);
	// cout<<rt<<"\n";
	dfs(rt,0,n);
	dfs1(rt,0);
	if(cnt>log2(n))
	{
		int ok=1/0;
	}
	cnt=0;
	return ;
}
signed main()
{
	// ios_base::sync_with_stdio(false);
	// cin.tie(nullptr);
	// cout.tie(nullptr);
	int _=1;
	cin>>_;
	while(_--){
		vision();
	}
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 0
Wrong Answer
time: 0ms
memory: 7660kb

input:

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

output:

? 3 1
! 5

result:

wrong answer There are 2 candidates. (test case 1)