ll@n,@q,a[n],b[n]; rep(i,n){ a[i]=i+1; b[i]=i-1; } a[n-1]=0; b[0]=n-1; 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[b[x]],b[a[x]])=(a[x],b[x]); } } if(t==2){ ll@u--; u=f(u); if(f.size(u)==n){ wt(-1); }else{ ll x=f(a[u]); wt(x+1); } } }