Problem C
Crystalfly
Paimon is catching crystalflies on a tree, which are a special kind of butterflies in Teyvat. A tree is a connected graph consisting of $n$ vertices and $(n - 1)$ undirected edges.
Pixiv ID: 93964680
There are initially $a_ i$ crystalflies on the $i$-th vertex. When Paimon reaches a vertex, she can catch all the remaining crystalflies on the vertex immediately. However, the crystalflies are timid. When Paimon reaches a vertex, all the crystalflies on the adjacent vertices will be disturbed. For the $i$-th vertex, if the crystalflies on the vertex are disturbed for the first time at the beginning of the $t’$-th second, they will disappear at the end of the $(t’ + t_{i})$-th second.
At the beginning of the $0$-th second, Paimon reaches vertex $1$ and stays there before the beginning of the $1$-st second. Then at the beginning of each following second, she can choose one of the two operations:
-
Move to one of the adjacent vertices of her current vertex and stay there before the beginning of the next second (if the crystalflies in the destination will disappear at the end of that second she can still catch them).
-
Stay still in her current vertex before the beginning of the next second.
Calculate the maximum number of crystalflies Paimon can catch in $10^{10^{10^{10^{10}}}}$ seconds.
Input
There are multiple test cases. The first line of the input contains an integer $T$ indicating the number of test cases. For each test case:
The first line contains an integer $n$ ($1 \le n \le 10^5$) indicating the number of vertices.
The second line contains $n$ integers $a_1, a_2, \cdots , a_ n$ ($1 \le a_ i \le 10^9$) where $a_ i$ is the number of crystalflies on the $i$-th vertex.
The third line contains $n$ integers $t_1, t_2, \cdots , t_ n$ ($1 \le t_ i \le 3$) where $t_ i$ is the time before the crystalflies on the $i$-th vertex disappear after disturbed.
For the next $(n - 1)$ lines, the $i$-th line contains two integers $u_ i$ and $v_ i$ ($1 \le u_ i, v_ i \le n$) indicating an edge connecting vertices $u_ i$ and $v_ i$ in the tree.
It’s guaranteed that the sum of $n$ of all the test cases will not exceed $10^6$.
Output
For each test case output one line containing one integer indicating the maximum number of crystalflies Paimon can catch.
Explanation
For the first sample test case, follow the strategy below.
-
During the $0$-th second
-
Paimon arrives at vertex $1$;
-
Paimon catches $1$ crystalfly;
-
Crystalflies in vertices $2$ and $3$ are disturbed.
-
-
During the $1$-st second
-
Paimon arrives at vertex $3$;
-
Paimon catches $100$ crystalflies.
-
-
During the $2$-nd second
-
Paimon arrives at vertex $1$;
-
Crystalflies in vertex $2$ disappears.
-
-
During the $3$-rd second
-
Paimon arrives at vertex $2$;
-
Crystalflies in vertices $4$ and $5$ are disturbed.
-
-
During the $4$-th second
-
Paimon arrives at vertex $5$;
-
Paimon catches $10000$ crystalflies;
-
Crystalflies in vertex $4$ disappears.
-
For the second sample test case, the optimal strategy is the same with the first sample test case. Crystalflies in vertex $2$ are scheduled to disappear at the end of the $3$-rd (instead of the $2$-nd) second, allowing Paimon to catch them.
Sample Input 1 | Sample Output 1 |
---|---|
2 5 1 10 100 1000 10000 1 2 1 1 1 1 2 1 3 2 4 2 5 5 1 10 100 1000 10000 1 3 1 1 1 1 2 1 3 2 4 2 5 |
10101 10111 |