제출 #1306413

#제출 시각아이디문제언어결과실행 시간메모리
1306413nguyenkhangninh99Klasika (COCI20_klasika)C++20
110 / 110
380 ms127740 KiB
#include<bits/stdc++.h> using namespace std; #define int long long const int maxn = 2e5 + 5, lg = 31; int tin[maxn], out[maxn], dist[maxn], timedfs; vector<int> stp[4 * maxn], stq[4 * maxn]; vector<pair<int, int>> g[maxn]; int trie[maxn * lg][2], hist[maxn * lg], top/*ptr for hist*/, triesz; int res[maxn], type[maxn]; struct pipi{ int a, b, t, id; } qry[maxn]; void dfs(int u, int p){ tin[u] = ++timedfs; for(pair<int, int> x: g[u]){ int v = x.first, w = x.second; dist[v] = dist[u] ^ w; dfs(v, u); } out[u] = timedfs; } void addp(int id, int l, int r, int p, int v){ stp[id].push_back(v); if(l == r) return; int mid = (l + r) / 2; if(p <= mid) addp(id * 2, l, mid, p, v); else addp(id * 2 + 1, mid + 1, r, p, v); } void addq(int id, int l, int r, int u, int v, int val){ if(u <= l && r <= v){ stq[id].push_back(val); return; } int mid = (l + r) / 2; if(u <= mid) addq(id * 2, l, mid, u, v, val); if(mid < v) addq(id * 2 + 1, mid + 1, r, u, v, val); } void insert(int val){ int u = 0; for(int bit = 30; bit >= 0; bit--){ int b = (val >> bit) & 1; if(!trie[u][b]){ trie[u][b] = ++triesz; hist[++top] = trie[u][b]; } u = trie[u][b]; } } int get(int val){ int u = 0, ans = 0; for(int bit = 30; bit >= 0; bit--){ int b = (val >> bit) & 1; if(trie[u][!b]){ ans |= (1LL << bit); u = trie[u][!b]; }else u = trie[u][b]; } return ans; } signed main(){ ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); int curq = 0, n = 1; int q; cin >> q; for(int i = 1; i <= q; i++){ string s; cin >> s; if(s == "Add"){ int v, w; cin >> v >> w; g[v].push_back({++n, w}); type[i] = 1; }else{ int a, b; cin >> a >> b; qry[curq++] = {a, b, n, i}; type[i] = 2; } } dfs(1, 0); for(int i = 1; i <= n; i++) addp(1, 1, n, tin[i], i); for(int i = 0; i < curq; i++) addq(1, 1, n, tin[qry[i].b], out[qry[i].b], i); for(int i = 1; i < 4 * maxn; i++){ int ptr = 0; for(int x: stq[i]){ while(ptr < stp[i].size() && stp[i][ptr] <= qry[x].t) insert(dist[stp[i][ptr++]]); res[qry[x].id] = max(res[qry[x].id], get(dist[qry[x].a])); } while(top){ int u = hist[top--]; trie[u][0] = trie[u][1] = 0; } trie[0][0] = trie[0][1] = triesz = 0; } for(int i = 0; i < curq; i++) cout << res[qry[i].id] << "\n"; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...