#10056. 「一本通 2.3 练习 5」The XOR-longest Path
大意:给你一个 n 各节点的带边权树,问你最大的路径异或值。
思路:dfs一遍求根节点到个点的路径异或值 T[i],则 a->b的路径异或值为T[a]^T[b]。然后异或字典树。
#include <bits/stdc++.h>
using namespace std;
const int maxn = 1e5+500;
struct node_e{
int en,v,va;
}e[maxn<<2];
int he[maxn],cnt;
int vis[maxn];
int tre[maxn*32][2],sz;
int mp[maxn];
int n,m;
void ade(int u,int v,int va){
e[++cnt].v=v;e[cnt].va=va;e[cnt].en=he[u];he[u]=cnt;
}
void dfs(int u){
vis[u] = 1;
for(int i=he[u];i;i=e[i].en){
int v = e[i].v;
if(vis[v]) continue;
mp[v] = mp[u]^e[i].va;
dfs(v);
}
}
void intre(int x){
int now = 0,tem;
for(int i=30;i>=0;--i){
tem = 1&&(x&(1<<i));
if(!tre[now][tem]) tre[now][tem] &#