//teja349
#include <bits/stdc++.h>
#include <vector>
#include <set>
#include <map>
#include <string>
#include <cstdio>
#include <cstdlib>
#include <climits>
#include <utility>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <iomanip>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp> 
//setbase - cout << setbase (16); cout << 100 << endl; Prints 64
//setfill -   cout << setfill ('x') << setw (5); cout << 77 << endl; prints xxx77
//setprecision - cout << setprecision (14) << f << endl; Prints x.xxxx
//cout.precision(x)  cout<<fixed<<val;  // prints x digits after decimal in val

using namespace std;
using namespace __gnu_pbds;

#define f(i,a,b) for(i=a;i<b;i++)
#define rep(i,n) f(i,0,n)
#define fd(i,a,b) for(i=a;i>=b;i--)
#define pb push_back
#define mp make_pair
#define vi vector< int >
#define vl vector< ll >
#define ss second
#define ff first
#define ll long long
#define pii pair< int,int >
#define pll pair< ll,ll >
#define sz(a) a.size()
#define inf (1000*1000*1000+5)
#define all(a) a.begin(),a.end()
#define tri pair<int,pii>
#define vii vector<pii>
#define vll vector<pll>
#define viii vector<tri>
#define mod (1000*1000*1000+7)
#define pqueue priority_queue< int >
#define pdqueue priority_queue< int,vi ,greater< int > >
#define flush fflush(stdout) 
#define primeDEN 727999983
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());

// find_by_order()  // order_of_key
typedef tree<
int,
null_type,
less<int>,
rb_tree_tag,
tree_order_statistics_node_update>
ordered_set;

vector< set<int> > adj(212345);

int subtree[212345];
int query(int val){
	cout<<1<<" "<<val<<endl;
	fflush(stdout);
	cin>>val;
	return val;
}

int dfs(int cur,int par){
	set<int>::iterator it;
	//cout<<cur<<" "<<par<<endl;
	subtree[cur]=1;
	for(it=adj[cur].begin();it!=adj[cur].end();it++){
		if(*it==par)
			continue;
		dfs(*it,cur);
		subtree[cur]+=subtree[*it];
	}

	return 0;
}
int findcentroid(int cur,int par,int req){
	set<int>::iterator it;
	for(it=adj[cur].begin();it!=adj[cur].end();it++){
		if(*it==par)
			continue;
		if(subtree[*it]>req){
			return findcentroid(*it,cur,req);
		}
	}
	return cur;
}
int solve(int cur){
	dfs(cur,-1);
	int val=findcentroid(cur,-1,subtree[cur]/2);
	//cout<<"centroid "<<subtree[cur]<<endl;
	int gg=query(val);
	if(gg==-1)
		return val;
	else{
		adj[gg].erase(val);
		return solve(gg);
	}


}
int main(){
    std::ios::sync_with_stdio(false); cin.tie(NULL);
	int t;
	cin>>t;
	while(t--){
		int n;
		cin>>n;
		int i;
		int u,v;
		rep(i,n+10){
			adj[i].clear();
		}
		rep(i,n-1){
			cin>>u>>v;
			adj[u].insert(v);
			adj[v].insert(u);
		}
		int ans=solve(1);
		cout<<2<<" "<<ans<<endl;
		cin>>ans;
		fflush(stdout);
	}
    return 0;   
}