Milk Visits (Gold)
Farmer John is planning to build n farms that will be connected by n − 1 roads, forming a tree (i.e., all farms are reachable from each-other, and there are no cycles). Each farm contains a cow with an integer type T[i]
between 1 and n inclusive.
Farmer John's m friends often come to visit him. During a visit with friend i, Farmer John will walk with his friend along the unique path of roads from farm A[i]
to farm B[i]
(it may be the case that A[i]
= B[i]
). Additionally, they can try some milk from any cow along the path they walk. Since most of Farmer John's friends are also farmers, they have very strong preferences regarding milk. Each of his friends will only drink milk from a certain type of cow. Any of Farmer John's friends will only be happy if they can drink their preferred type of milk during their visit.
Please determine whether each friend will be happy after visiting.
Input
The first line contains two integer n (1 ≤ n ≤ 10^5
) and m (1 ≤ m ≤ 10^5
). The second line contains n integers T[1]
, T[2]
,..., T[n]
. The type of the cow in the i-th farm is denoted by T[i]
.
The next n − 1 lines each contain two distinct integers x and y (1 ≤ x, y ≤ n), indicating that there is an edge between farms x and y.
The next m lines contain integers A[i]
, B[i]
and C[i]
. A[i]
and B[i]
represent the endpoints of the path walked during friend i's visit, while C[i]
(1 ≤ C[i]
≤ n) indicates the type of cow whose milk the friend enjoys drinking.
Output
Print a binary string of length m. The i-th character of the string should be '1' if the i-th friend will be happy, or '0' otherwise.
Example
In this example, the path from 1 and 4 involves farms 1, 2 and 4. All of these contain cows of type 1, so the first friend will be satisfied while the second one will not.