This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
/**
* author: wxhtzdy
* created: 08.08.2022 17:17:05
**/
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 200005 * 30;
set<int> ids[MAXN];
int trie[MAXN][2];
int main() {
ios::sync_with_stdio(false);
cin.tie(0);
int q;
cin >> q;
vector<string> op(q);
vector<int> x(q);
vector<int> y(q);
int n = 1;
vector<vector<pair<int, int>>> g(1);
for (int i = 0; i < q; i++) {
cin >> op[i] >> x[i] >> y[i];
if (op[i] == "Add") {
--x[i];
g.push_back({});
g[x[i]].emplace_back(n, y[i]);
n += 1;
} else {
--x[i]; --y[i];
}
}
vector<int> dep(n);
vector<int> tin(n);
vector<int> tout(n);
int T = -1;
function<void(int, int)> Dfs = [&](int v, int pr) {
tin[v] = ++T;
for (auto& p : g[v]) {
int u = p.first;
int w = p.second;
if (u != pr) {
dep[u] = dep[v] ^ w;
Dfs(u, v);
}
}
tout[v] = T;
};
Dfs(0, 0);
int idx = 1;
for (int i = 0; i < MAXN; i++) {
trie[i][0] = trie[i][1] = -1;
}
int ii = 1;
auto Add = [&](int v, int id) {
int p = 0;
for (int i = 30; i >= 0; i--) {
int bit = (v >> i & 1);
if (trie[p][bit] == -1) {
trie[p][bit] = ii++;
}
p = trie[p][bit];
ids[p].insert(id);
}
};
Add(dep[0], tin[0]);
for (int i = 0; i < q; i++) {
if (op[i] == "Add") {
Add(dep[idx], tin[idx]);
idx += 1;
} else {
int p = 0;
int ans = 0;
for (int j = 30; j >= 0; j--) {
int bit = (dep[x[i]] >> j & 1);
if (trie[p][bit ^ 1] != -1) {
auto it = ids[trie[p][bit ^ 1]].lower_bound(tin[y[i]]);
if (it != ids[trie[p][bit ^ 1]].end() && *it <= tout[y[i]]) {
ans += (1 << j);
p = trie[p][bit ^ 1];
} else {
p = trie[p][bit];
}
} else {
p = trie[p][bit];
}
}
cout << ans << '\n';
}
}
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |