The Xor-longest Path [WOJ2290] [0/1trie]

本文探讨了在树状数据结构中使用异或运算优化路径查询的方法,通过维护从每个节点到根节点的异或和,利用0/1 Trie数据结构找到具有最大异或值的两个点,从而高效解决特定类型的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

传送门

考虑维护每个点到根的异或和 , 发现一条路径两个点的异或和就是他们到根的异或和的异或

因为lca 到根的那一段自己与自己异或 , 就变成0了 , 接着就变成找两个异或最大的点 , 0/1trie 解决

#include<bits/stdc++.h>
#define N 100050
using namespace std;
int first[N],next[N*2],to[N*2],w[N*2],tot;
int dis[N],ch[N*32][2],val[N*32],n,m,ans,sign;
void add(int x,int y,int z){
	next[++tot]=first[x],first[x]=tot,to[tot]=y,w[tot]=z;
}
void dfs(int u,int f){
	for(int i=first[u];i;i=next[i]){
		int t=to[i]; if(t==f) continue;
		dis[t] = dis[u] ^ w[i]; dfs(t,u);
	}
}
void Insert(int x){
	int now = 0;
	for(int i=31;i>=0;i--){
		int pos = ((x>>i)&1);
		if(!ch[now][pos]) ch[now][pos]=++sign;
		now = ch[now][pos];
	} val[now] = x;
}
int Quary(int x){
	int now = 0;
	for(int i=31;i>=0;i--){
		int pos = ((x>>i)&1)==0;
		if(ch[now][pos]) now = ch[now][pos];
		else now = ch[now][pos^1]; 
	} return val[now];
}
int main(){
	scanf("%d%d",&n,&m);
	for(int i=1;i<n;i++){
		int x,y,z; scanf("%d%d%d",&x,&y,&z);
		add(x,y,z),add(y,x,z);
	} dfs(1,0);
	for(int i=1;i<=n;i++){
		ans = max(ans,dis[i]^Quary(dis[i])); 
		Insert(dis[i]^m);
	} printf("%d",ans); return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FSYo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值