Submission #203234

#TimeUsernameProblemLanguageResultExecution timeMemory
203234luciocfKlasika (COCI20_klasika)C++14
33 / 110
3076 ms430304 KiB
#include <bits/stdc++.h> using namespace std; typedef pair<int, int> pii; const int maxn = 2e5+10; struct Q { int op, u, v, vert; } query[maxn]; struct Node { Node *b[2]; set<pii> S; Node() { b[0] = b[1] = NULL; } }; int n=1; int path[maxn]; int st[maxn], en[maxn], tt; vector<int> grafo[maxn]; void dfs(int u, int p) { st[u] = ++tt; for (auto v: grafo[u]) if (v != p) dfs(v, u); en[u] = tt; } void add(Node *t, int u, int v) { Node *at = t; for (int i = 30; i >= 0; i--) { if (v&(1<<i)) { if (!at->b[1]) at->b[1] = new Node(); at = at->b[1]; } else { if (!at->b[0]) at->b[0] = new Node(); at = at->b[0]; } at->S.insert({en[u], st[u]}); } } int get_max(Node *t, int u, int v) { Node *at = t; int ans = 0; for (int i = 30; i >= 0; i--) { Node *l = at->b[0], *r = at->b[1]; if (v&(1<<i)) { if (l == NULL) { at = r; continue; } set<pii>::iterator it = l->S.upper_bound({en[u], n+1}); if (it == l->S.begin()) { at = r; continue; } --it; if (it->second >= st[u]) { ans += (1<<i); at = l; } else at = r; } else { if (r == NULL) { at = l; continue; } set<pii>::iterator it = r->S.upper_bound({en[u], n+1}); if (it == r->S.begin()) { at = l; continue; } --it; if (it->second >= st[u]) { ans += (1<<i); at = r; } else at = l; } } return ans; } int main(void) { int q; scanf("%d", &q); for (int i = 1; i <= q; i++) { string s; cin >> s; int u, v; scanf("%d %d", &u, &v); if (s[0] == 'A') { grafo[u].push_back(++n); grafo[n].push_back(u); path[n] = path[u]^v; query[i] = {0, u, v, n}; } else query[i] = {1, u, v, 0}; } dfs(1, 0); Node *root = new Node(); add(root, 1, 0); for (int i = 1; i <= q; i++) { int u = query[i].u, v = query[i].v; if (query[i].op == 1) printf("%d\n", get_max(root, v, path[u])); else add(root, query[i].vert, path[query[i].vert]); } }

Compilation message (stderr)

klasika.cpp: In function 'int main()':
klasika.cpp:133:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d", &q);
  ~~~~~^~~~~~~~~~
klasika.cpp:141:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d %d", &u, &v);
   ~~~~~^~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...