QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#729957#9570. Binary Treeucup-team3282TL 0ms0kbC++141.6kb2024-11-09 18:06:402024-11-09 18:06:41

Judging History

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

  • [2024-11-09 18:06:41]
  • 评测
  • 测评结果:TL
  • 用时:0ms
  • 内存:0kb
  • [2024-11-09 18:06:40]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll MAXN=5e5+5;
ll t,n;
struct edge{
	ll u,v,nxt;
}e[MAXN];
ll head[MAXN],edge_num;
void add_edge(ll From,ll To){
	e[++edge_num]=(edge){From,To,head[From]};
	head[From]=edge_num;
	return;
}
bool vis[MAXN];
ll deep[MAXN];
ll res;
ll fa[MAXN];
void solve(ll now,ll father){
	deep[now]=deep[father]+1;
	fa[now]=father;
	if(deep[now]>deep[res])res=now;
	for(int i=head[now];i;i=e[i].nxt){
		if(vis[e[i].v]||e[i].v==father)continue;
		solve(e[i].v,now);
	}
	return;
}
ll x,y;
int main(){
	cin>>t;
	while(t--){
		cin>>n;
		for(int i=1;i<=n;i++){
			cin>>x>>y;
			if(x){
				add_edge(i,x);
				add_edge(x,i);
			}
			if(y){
				add_edge(i,y);
				add_edge(y,i);
			}
		}
		ll L=1,R=n;
		res = 0;
		solve(1,1);
		L=res;
		res=0;
		solve(L,L);
		R=res;
		while(L!=R){
			ll tmp;
			cout<<"? "<<L<<" "<<R<<endl;
			cin>>tmp;
			
			if (tmp == 1)
			{
				int u = R;
				while (deep[u] * 2 != deep[L] + deep[R])
				{
					vis[u] = 1;
					u = fa[u];
				}
				vis[fa[u]] = 1;
				
				res = 0;
				solve(u, u);
				L = res;
				res=0;
				solve(L, L);
				R = res;
			}
			
			if (tmp == 2)
			{
				swap(L,R);
				res=0;
				solve(L,L);
			}
			
			int u = R;
			while (deep[u] - deep[L] >= deep[R] - deep[u])
			{
				vis[u] = 1;
				u = fa[u];
			}
			R = u;
			
			res = 0;
			solve(L, L);
			L = res;
			res=0;
			solve(L, L);
			R = res;
		}
		
		cout << "! " << L <<endl;
		for(int i=1;i<=n;i++)vis[i]=head[i]=fa[i]=deep[i]=0;
		edge_num=0;
		//clear all array !
	}
	return 0;
}

详细

Test #1:

score: 0
Time Limit Exceeded

input:

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

output:

? 4 5
? 1 5

result: