Submission #1098641

#TimeUsernameProblemLanguageResultExecution timeMemory
1098641hiensumiKlasika (COCI20_klasika)C++14
33 / 110
1411 ms524288 KiB
#include <bits/stdc++.h> using namespace std; #define fod(i,a,b) for(int i = (int) (a); i <= (int) (b); i++) #define fok(i,a,b) for(int i = (int) (a); i >= (int) (b); i--) #define ll long long #define pb push_back #define pii pair<int,int> #define mp make_pair #define fi first #define se second #define el '\n' #define ve vector #define vi ve<int> #define vll ve<ll> #define mask(a) (1LL<<(a)) #define BIT(msk,i) (msk>>(i)&1LL) using namespace std; template <class T> bool mini(T &a, T b){ return (a > (b)) ? a = (b), 1 : 0; } template <class T> bool maxi(T &a, T b){ return (a < (b)) ? a = (b), 1 : 0; } #define name "klasika" int n = 1, q; const int N = 2e5; struct Query{ bool new_node; int x, y; }query[N + 5]; ve <ve<pii>> g; int in[N + 5], out[N + 5], timedfs = 0; int f[N + 5]; void dfs(int u, int p){ in[u] = ++timedfs; for(pii who : g[u]) if(who.fi != p){ int v, w; tie(v, w) = who; f[v] = f[u] xor w; dfs(v, u); } out[u] = timedfs; } struct Node{ set <int> ids; Node* nxt[31]; Node(){ ids.clear(); fod(j,0,30) nxt[j] = NULL; } }; Node* root = new Node(); inline void add(int val, int id){ Node* cur = root; fok(j,30,0){ int w = BIT(val, j); if(cur -> nxt[w] == NULL) cur -> nxt[w] = new Node(); cur = cur -> nxt[w]; cur -> ids.insert(id); } } int get(int val, int l, int r){ Node* cur = root; int res = 0; fok(j,30,0){ int w = BIT(val, j); if(cur -> nxt[w^1] == NULL) cur = cur -> nxt[w]; else{ if(cur -> nxt[w^1] -> ids.lower_bound(l) == cur -> nxt[w^1] -> ids.upper_bound(r)){ cur = cur -> nxt[w]; continue; } res += mask(j); cur = cur -> nxt[w^1]; } } return res; } int main(){ ios_base::sync_with_stdio(false); cin.tie(0); cin >> q; g.resize(q + 1); fod(i,1,q){ string s; cin >> s; int x, y; cin >> x >> y; if(s == "Add"){ n++; g[x].pb(mp(n, y)); g[n].pb(mp(x, y)); query[i] = Query{1, n, y}; } else query[i] = Query{0, x, y}; } dfs(1, 0); add(f[1], in[1]); fod(i,1,q){ if(query[i].new_node){ add(f[query[i].x], in[query[i].x]); } else{ cout << get(f[query[i].x], in[query[i].y], out[query[i].y]) << el; } } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...