This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
///giangcbg - TST 2022.
#include <bits/stdc++.h>
#define reset(x, val) memset((x), (val), sizeof (x))
#define bit(X, i) (((X) >> (i)) & 1)
#define all(X) (X).begin(), (X).end()
#define on(X,i) (X|(1<<i))
#define off(X,i) (X^(1<<i))
#define cntbit(X) __builtin_popcountll(X)
#define pb push_back
#define ep emplace_back
#define fi first
#define se second
using namespace std;
const char ginp[]="KLASIKA.INP";
const char gout[]="KLASIKA.OUT";
void debug_out() { cerr << '\n'; }
template <typename Head, typename ...Tail>
void debug_out(Head H, Tail ...T)
{
cerr << " " << H;
debug_out(T...);
}
#define debug(...) cerr << "[" << #__VA_ARGS__ << "]:", debug_out(__VA_ARGS__)
void read() {}
template <typename Head, typename ...Tail>
void read(Head &H, Tail &...T)
{
register char c;
bool sign = 0;
for (c = getchar(); !isdigit(c); c = getchar())
if (c == '-') sign = !sign;
H = c - '0';
for (c = getchar(); isdigit(c); c = getchar())
H = H * 10 + c - '0';
if (sign) H = -H;
read(T...);
}
typedef long long ll;
typedef pair <int, int> ii;
typedef pair <int, ii> iii;
typedef vector <int> vi;
typedef vector <ii> vii;
mt19937 rd(chrono :: steady_clock :: now().time_since_epoch().count());
#define rand rd
ll Rand(ll l, ll h) { return l + rand() % (h - l + 1); }
const int dx[] = {-1, 0, 1, 0};
const int dy[] = {0, 1, 0, -1};
const int N = 2e5 + 5;
const int oo = 1e9 + 7;
struct query
{
string s;
int a,b;
};
struct Trie
{
Trie *c[2];
set <int> s;
Trie()
{
c[0] = c[1] = nullptr;
s.clear();
}
};
Trie *root;
int m,n;
query q[N];
vi g[N];
int in[N], out[N], f[N];
void enter()
{
cin >> m;
n = 1;
f[1] = 0; ///sumXor
for (int i = 1; i <= m; i++)
{
cin >> q[i].s >> q[i].a >> q[i].b;
//debug(q[i].s, q[i].a, q[i].b);
if (q[i].s == "Add")
{
++n;
g[q[i].a].pb(n);
f[n] = f[q[i].a] ^ q[i].b;
q[i].a = n; q[i].b = f[n];
}
}
}
void dfs(int u)
{
in[u] = ++in[0];
for (int v : g[u]) dfs(v);
out[u] = ++in[0];
}
void Add(int x, int time)
{
Trie *p = root;
for (int i = 30; i >= 0; i--)
{
int id = bit(x,i);
if (p -> c[id] == nullptr) p -> c[id] = new Trie();
p = p -> c[id];
p -> s.insert(time);
}
}
bool check(Trie *p, int b)
{
auto it = p->s.lower_bound(in[b]);
if (it == p->s.end() || *it > out[b]) return 0;
return 1;
}
int Find(int a, int b)
{
Trie *p = root;
int x = f[a], res = 0;
for (int i = 30; i >= 0; i--)
{
int id = bit(x,i);
if (p -> c[!id] != nullptr && check(p -> c[!id], b))
{
res |= (1<<i);
p = p -> c[!id];
}
else p = p -> c[id];
}
return res;
}
void solve()
{
dfs(1);
root = new Trie();
Add(f[1], in[1]);
for (int i = 1; i <= m; i++)
{
if (q[i].s == "Query") cout << Find(q[i].a, q[i].b) << '\n';
else Add(q[i].b, in[q[i].a]);
}
}
int main()
{
ios_base::sync_with_stdio(0);cin.tie(0); cout.tie(0);
#ifndef ONLINE_JUDGE
//freopen(ginp, "r", stdin);
//freopen(gout, "w", stdout);
#endif // ONLINE_JUDGE
enter();
solve();
cerr << "\nTime : " << clock() << "ms\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... |