ll@n,@q,a[n]; rep(i,n-1){ a[i]=i+1; } a[n-1]=0; unionFind f('m',n,1); rep(q){ ll@t; if(t==1){ ll@u--,@v--; u=f(u); v=f(v); if(f(u,v)){ ll r=f(u); ll x=r^u^v; if(f(a[x])!=r){ f(a[x])=r; } } } if(t==2){ ll@u--; u=f(u); if(f.size(u)==n){ wt(-1); }else{ ll x=f(a[u]); wt(x+1); } } }