#P3359. 改造异或树

改造异或树

题目描述

给定一棵 nn 个点的树,每条边上都有一个权值。现在按顺序删掉所有的 n1n-1 条边,每删掉一条边询问当前有多少条路径满足路径上所有边权值异或和为 00

输入格式

第一行一个整数 nn

接下来 n1n-1 行,每行三个整数 ai,bi,zia_i,b_i,z_i,满足 1ai,bin1\le ai,bi\le n,表示树上编号为 aia_i 的点和编号为bib_i 的点中间连有一条权值为 ziz_i 的边。

接下来一行 n1n-1 个整数,两两之间有一个空格隔开,表示一个 1n11\sim n- 1 的排列,表示 n1n - 1 条边的删边顺序。

输出格式

输出 nn 行,每行一个整数,依次表示删掉第 0n10\sim n - 1 条边之后的边权异或和为零的路径数。

4
1 2 0
2 3 0
2 4 0
3 1 2
6
3
1
0

提示

对于 20%20\% 数据,满足 n1000n\le 1000

对于另外 30%30\% 数据,满足所有的 zi=0z_i = 0

对于全部数据,满足 n105,0zi109n\le 10^5,0\le z_i\le 10^9