This story is happening in a town named BubbleLand. There are n houses in BubbleLand. In each of these n houses lives a boy or a girl. People there really love numbers and everyone has their favorite number f. That means that the boy or girl that lives in the i-th house has favorite number equal to f i.
The houses are numerated with numbers 1 to n.
The houses are connected with n - 1 bidirectional roads and you can travel from any house to any other house in the town. There is exactly one path between every pair of houses.
A new dating had agency opened their offices in this mysterious town and the citizens were very excited. They immediately sent q questions to the agency and each question was of the following format:
- a b — asking how many ways are there to choose a couple (boy and girl) that have the same favorite number and live in one of the houses on the unique path from house a to house b.
Help the dating agency to answer the questions and grow their business.
Input
The first line contains an integer n (1 ≤ n ≤ 105), the number of houses in the town.
The second line contains n integers, where the i-th number is 1 if a boy lives in the i-th house or 0 if a girl lives in i-th house.
The third line contains n integers, where the i-th number represents the favorite number f i (1 ≤ f i ≤ 109) of the girl or boy that lives in the i-th house.
The next n - 1 lines contain information about the roads and the i-th line contains two integers a i and b i (1 ≤ a i, b i ≤ n) which means that there exists road between those two houses. It is guaranteed that it’s possible to reach any house from any other.
The following line contains an integer q (1 ≤ q ≤ 105), the number of queries.
Each of the following q lines represents a question and consists of two integers a and b (1 ≤ a, b ≤ n).
Output
For each of the q questions output a single number, the answer to the citizens question.
Example
input
7
1 0 0 1 0 1 0
9 2 9 2 2 9 9
2 6
1 2
4 2
6 5
3 6
7 4
2
1 3
7 5
output
2
3
Note
In the first question from house 1 to house 3, the potential couples are (1, 3) and (6, 3).
In the second question from house 7 to house 5, the potential couples are (7, 6), (4, 2) and (4, 5).
#include <bits/stdc++.h> using namespace std; struct Query { int a; int b; int coeff; int id; }; int BLOCK; inline bool cmp(Query &x, Query &y) { int X = x.a / BLOCK; int Y = y.a / BLOCK; if (X != Y) { return X < Y; } return x.b < y.b; } const int N = 100010; const int LOG = 20; vector <int> order; int entry[N], brexit[N]; int pv[N]; int pr[N][LOG]; Query qs[16 * N]; long long result[N]; int in_a[N], in_b[N]; int label[N]; vector <int> g[N]; int depth[N]; pair <int, int> ev[N]; int type[N]; void dfs(int v, int pr) { entry[v] = order.size(); order.push_back(v); int sz = g[v].size(); for (int j = 0; j < sz; j++) { int u = g[v][j]; if (u != pr) { pv[u] = v; depth[u] = depth[v] + 1; dfs(u, v); } } brexit[v] = order.size(); order.push_back(~v); } inline bool anc(int x, int y) { return (entry[x] <= entry[y] && brexit[y] <= brexit[x]); } inline int lca(int x, int y) { if (anc(x, y)) { return x; } for (int j = LOG - 1; j >= 0; j--) { if (!anc(pr[x][j], y)) { x = pr[x][j]; } } return pr[x][0]; } int main() { int n; scanf("%d", &n); for (int i = 0; i < n; i++) { scanf("%d", type + i); } for (int i = 0; i < n; i++) { scanf("%d", &ev[i].first); ev[i].second = i; } sort(ev, ev + n); int cur_label = 0; for (int i = 0; i < n; i++) { if (i > 0 && ev[i].first != ev[i - 1].first) { cur_label++; } label[ev[i].second] = cur_label; } for (int i = 0; i < n - 1; i++) { int foo, bar; scanf("%d %d", &foo, &bar); foo--; bar--; g[foo].push_back(bar); g[bar].push_back(foo); } int tt; scanf("%d", &tt); pv[0] = 0; depth[0] = 0; dfs(0, -1); for (int i = 0; i < n; i++) { pr[i][0] = pv[i]; } for (int j = 1; j < LOG; j++) { for (int i = 0; i < n; i++) { pr[i][j] = pr[pr[i][j - 1]][j - 1]; } } int cnt = 0; for (int i = 0; i < tt; i++) { int w, x, y, z; scanf("%d %d", &w, &x); y = w; z = x; w--; x--; y--; z--; vector < pair <int, int> > a, b; { int LCA = lca(w, x); a.push_back(make_pair(w, 1)); a.push_back(make_pair(x, 1)); a.push_back(make_pair(LCA, -1)); if (LCA != 0) { a.push_back(make_pair(pv[LCA], -1)); } } { int LCA = lca(y, z); b.push_back(make_pair(y, 1)); b.push_back(make_pair(z, 1)); b.push_back(make_pair(LCA, -1)); if (LCA != 0) { b.push_back(make_pair(pv[LCA], -1)); } } for (int ia = 0; ia < (int) a.size(); ia++) { for (int ib = 0; ib < (int) b.size(); ib++) { Query &q = qs[cnt++]; q.a = entry[a[ia].first]; q.b = entry[b[ib].first]; q.coeff = a[ia].second * b[ib].second; q.id = i; // result[i] -= q.coeff * (depth[lca(order[q.a], order[q.b])] + 1); // cerr << "query " << q.a << " " << q.b << " " << q.coeff << " " << q.id << " -> " << result[i] << endl; } } } BLOCK = (int) (1 + sqrt(order.size())); sort(qs, qs + cnt, cmp); long long sum = 0; int x = -1, y = -1; for (int id = 0; id < cnt; id++) { Query &q = qs[id]; while (x < q.a) { x++; if (type[order[x] >= 0 ? order[x] : ~order[x]] == 0) { if (order[x] >= 0) { sum += in_b[label[order[x]]]; in_a[label[order[x]]]++; } else { sum -= in_b[label[~order[x]]]; in_a[label[~order[x]]]--; } } } while (y < q.b) { y++; if (type[order[y] >= 0 ? order[y] : ~order[y]] == 1) { if (order[y] >= 0) { sum += in_a[label[order[y]]]; in_b[label[order[y]]]++; } else { sum -= in_a[label[~order[y]]]; in_b[label[~order[y]]]--; } } } while (x > q.a) { if (type[order[x] >= 0 ? order[x] : ~order[x]] == 0) { if (order[x] >= 0) { sum -= in_b[label[order[x]]]; in_a[label[order[x]]]--; } else { sum += in_b[label[~order[x]]]; in_a[label[~order[x]]]++; } } x--; } while (y > q.b) { if (type[order[y] >= 0 ? order[y] : ~order[y]] == 1) { if (order[y] >= 0) { sum -= in_a[label[order[y]]]; in_b[label[order[y]]]--; } else { sum += in_a[label[~order[y]]]; in_b[label[~order[y]]]++; } } y--; } result[q.id] += q.coeff * sum; } for (int i = 0; i < tt; i++) { printf("%lld\n", result[i]); } return 0; }