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; a[x]=r; } } if(t==2){ ll@u--; u=f(u); ll x=f(a[u]); wt(x==u?-1:x+1); } }