标签:-- 接下来 题目 head i++ 根据 相同 www. 元素
int n,tot,ans;
int dis[100005],ch[3000005][2];
int cnt,head[100005],nxt[200005];
int to[200005],w[200005];
void add(int a,int b,int c){
nxt[++cnt]=head[a];
head[a]=cnt;
to[cnt]=b;
w[cnt]=c;
}//还没忘记链式前向星...
void dfs(int x,int father){
for(int i=head[x];i;i=nxt[i]){
int y=to[i];
if(y==father)continue;//这里注意一下
dis[y]=dis[x]^w[i];
dfs(y,x);
}
}
void insert(int x){//Trie树插入操作的模板
int u=0;
for(int i=31;i>=0;i--){
int c=(x&(1<<i))>>i;
//1<<i,即2^i;
//x&(1<<i)得到x的二进制数从低到高的第i位是1还是0
//如果是0,则c等于0;如果是1,则c=(2^i)>>i=1
if(!ch[u][c])ch[u][c]=++tot;
u=ch[u][c];
}
}
int query(int x){
int u=0,ans=0;
for(int i=31;i>=0;i--){
int c=(x&(1<<i))>>i;
if(ch[u][c^1]){
c要么0要么1,0^1=1,1^0=0,所以c^1相当于!c
ans+=(1<<i);
//如果走了与当前位相反的字符指针,则对答案产生贡献
u=ch[u][c^1];
}
else u=ch[u][c];
}
return ans;
}
int main(){
n=read();//n个节点
for(int i=1;i<=n-1;i++){
int a=read(),b=read(),c=read();
add(a,b,c);add(b,a,c);
}//建图
dfs(1,0);//DFS预处理出dis数组
for(int i=1;i<=n;i++)
insert(dis[i]);
//将dis数组插入Trie树
for(int i=1;i<=n;i++)
ans=max(ans,query(dis[i]));
printf("%d\n",ans);
return 0;
}
标签:-- 接下来 题目 head i++ 根据 相同 www. 元素
原文地址:https://www.cnblogs.com/PPXppx/p/10339483.html