Rowena Ravenclaw’s Diadem

Harry, upon inquiring Helena Ravenclaw’s ghost, came to know that she told Tom Riddle or You-know-who about Rowena Ravenclaw’s diadem and that he stole it from her.

Harry thought that Riddle would have assumed that he was the only one to discover the Room of Requirement and thus, would have hidden it there. So Harry is trying to get inside the Room of Requirement to destroy the diadem as he knows that it is a horcrux.

But he has to answer a puzzle in order to enter the room. He is given n objects, numbered from 1 to n. Some of the objects have a parent object, that has a lesser number. Formally, object i may have a parent object parent i such that parent i < i.

There is also a type associated with each parent relation, it can be either of type 1 or type 2. Type 1 relation means that the child object is like a special case of the parent object. Type 2 relation means that the second object is always a part of the first object and all its special cases.

Note that if an object b is a special case of object a, and c is a special case of object b, then c is considered to be a special case of object a as well. The same holds for parts: if object b is a part of a, and object c is a part of b, then we say that object c is a part of a. Also note, that if object b is a part of a, and object c is a special case of a, then b is a part of c as well.

An object is considered to be neither a part of itself nor a special case of itself.

Now, Harry has to answer two type of queries:

  • 1 u v: he needs to tell if object v is a special case of object u.
  • 2 u v: he needs to tell if object v is a part of object u.

Input

First line of input contains the number n (1 ≤ n ≤ 105), the number of objects.

Next n lines contain two integer parent i and type i ( - 1 ≤ parent i < i parent i ≠ 0,  - 1 ≤ type i ≤ 1), implying that the i-th object has the parent parent i. (If type i = 0, this implies that the object i is a special case of object parent i. If type i = 1, this implies that the object i is a part of object parent i). In case the i-th object has no parent, both parent i and type i are -1.

Next line contains an integer q (1 ≤ q ≤ 105), the number of queries.

Next q lines each represent a query having three space separated integers type i, u i, v i (1 ≤ type i ≤ 2, 1 ≤ u, v ≤ n).

Output

Output will contain q lines, each containing the answer for the corresponding query as “YES” (affirmative) or “NO” (without quotes).

You can output each letter in any case (upper or lower).

Examples

input

3
-1 -1
1 0
2 0
2
1 1 3
2 1 3

output

YES
NO

input

3
-1 -1
1 0
1 1
2
2 2 3
2 3 2

output

YES
NO

Note

In test case 1, as object 2 is a special case of object 1 and object 3 is a special case of object 2, this makes object 3 a special case of object 1.

In test case 2, as object 2 is a special case of object 1 and object 1 has object 3, this will mean that object 2 will also have object 3. This is because when a general case (object 1) has object 3, its special case (object 2) will definitely have object 3.

Solution:

#include <bits/stdc++.h>

using namespace std;

const int N = 1234567;

int TIME = 0, tin[N], tout[N];
int de[N];
vector<int> g[N];
int parent[N], type[N];
int upper_special[N];
int upper_part[N];

void dfs(int v) {
tin[v] = ++TIME;
for (int u : g[v]) {
de[u] = de[v] + 1;
dfs(u);
}
tout[v] = ++TIME;
}

inline bool anc(int x, int y) {
return (tin[x] <= tin[y] && tout[y] <= tout[x]);
}

int main() {
  int n;
  scanf("%d", &n);
  for (int i = 0; i < n; i++) {
    scanf("%d %d", parent + i, type + i);
    if (parent[i] != -1) {
      parent[i]--;
    }
  }
  for (int i = 0; i < n; i++) {
    upper_special[i] = i;
    if (type[i] == 0) {
      upper_special[i] = upper_special[parent[i]];
    }
    upper_part[i] = i;
    if (type[i] == 1) {
      upper_part[i] = upper_part[parent[i]];
    }
  }
  for (int i = 0; i < n; i++) {
    g[parent[i]].push_back(i);
  }
  for (int i = 0; i < n; i++) {
    if (parent[i] == -1) {
      de[i] = 0;
      dfs(i);
    }
  }
  int tt;
  scanf("%d", &tt);
  while (tt--) {
    int op, x, y;
    scanf("%d %d %d", &op, &x, &y);
    x--; y--;
    if (x == y) {
      puts("NO");
      continue;
    }
    if (op == 1) {
      if (anc(x, y) && de[upper_special[y]] <= de[x]) {
        puts("YES");
      } else {
        puts("NO");
      }
    } else {
      int z = upper_part[y];
      if (y != z && anc(z, x) && de[upper_special[x]] <= de[z]) {
        puts("YES");
      } else {
        z = upper_special[x];
        if (y != z && anc(z, y) && de[upper_part[y]] <= de[z]) {
          puts("YES");
        } else {
          puts("NO");
        }
      }
    }
  }
  return 0;
}