LCT秒天秒地
树剖比较裸的题了
用线段树记录一下区间的最左边的黑点的编号(因为同一条链上肯定是最左边的深度最小,到根节点距离最近)
然后记得树剖的时候肯定是越后面的答案越优,因为深度越浅
//minamoto
#include<bits/stdc++.h>
using namespace std;
#define getc() (p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++)
char buf[<<],*p1=buf,*p2=buf;
inline int read(){
#define num ch-'0'
char ch;bool flag=;int res;
while(!isdigit(ch=getc()))
(ch=='-')&&(flag=true);
for(res=num;isdigit(ch=getc());res=res*+num);
(flag)&&(res=-res);
#undef num
return res;
}
char sr[<<],z[];int C=-,Z;
inline void Ot(){fwrite(sr,,C+,stdout),C=-;}
inline void print(int x){
if(C><<)Ot();if(x<)sr[++C]=,x=-x;
while(z[++Z]=x%+,x/=);
while(sr[++C]=z[Z],--Z);sr[++C]='\n';
}
const int N=1e5+;
int head[N],Next[N<<],ver[N<<],tot;
inline void add(int u,int v){
ver[++tot]=v,Next[tot]=head[u],head[u]=tot;
}
int dfn[N],sz[N],son[N],fa[N],bl[N],val[N],top[N],cnt,n,m;
void dfs1(int u){
sz[u]=;
for(int i=head[u];i;i=Next[i]){
int v=ver[i];
if(v!=fa[u]){
fa[v]=u,dfs1(v),sz[u]+=sz[v];
if(sz[son[u]]<sz[v]) son[u]=v;
}
}
}
void dfs2(int u,int t){
dfn[u]=++cnt,bl[cnt]=u,top[u]=t;
if(son[u]){
dfs2(son[u],t);
for(int i=head[u];i;i=Next[i]){
int v=ver[i];
if(v!=fa[u]&&v!=son[u]) dfs2(v,v);
}
}
}
int mx[N<<];
#define ls (p<<1)
#define rs (p<<1|1)
inline void upd(int p){
mx[p]=mx[ls]?mx[ls]:mx[rs];
}
void build(int p,int l,int r){
if(l==r) return (void)(mx[p]=val[bl[l]]?bl[l]:);
int mid=(l+r)>>;
build(ls,l,mid),build(rs,mid+,r);
upd(p);
}
void update(int p,int l,int r,int x){
if(l==r) return (void)(mx[p]=val[bl[l]]?bl[l]:);
int mid=(l+r)>>;
x<=mid?update(ls,l,mid,x):update(rs,mid+,r,x);
upd(p);
}
int query(int p,int l,int r,int ql,int qr){
if(ql<=l&&qr>=r) return mx[p];
int mid=(l+r)>>,res=;
if(ql<=mid&&(res=query(ls,l,mid,ql,qr))) return res;
if(qr>mid&&(res=query(rs,mid+,r,ql,qr))) return res;
return ;
}
inline void change(int i){
val[i]^=,update(,,n,dfn[i]);
}
inline int get(int u){
int res=,p;
while(top[u]!=){
p=query(,,n,dfn[top[u]],dfn[u]);
p?res=p:;
u=fa[top[u]];
}
p=query(,,n,,dfn[u]);p?res=p:;
return res?res:-;
}
int main(){
// freopen("testdata.in","r",stdin);
n=read(),m=read();
for(int i=,u,v;i<n;++i)
u=read(),v=read(),add(u,v),add(v,u);
dfs1(),dfs2(,),build(,,n);
while(m--){
int op=read(),u=read();
op&?print(get(u)):change(u);
}
Ot();
return ;
}