#include <bits/stdc++.h>
using namespace std;
int n = 1;
int cnt = 0;
static vector<int> adj[200005];
static int low[200005];
static int high[200005];
static int XOR[200005];
void dfs(int u){
low[u] = cnt;
high[u] = cnt;
cnt++;
for(int v : adj[u]){
dfs(v);
high[u] = max(high[u], high[v]);
}
}
typedef pair<int,int> ii;
vector<ii> queries;
int N = 0;
static ii trie[4000005];
static set<int> S[4000005];
int CNT = 2;
void INS(int x, int pos){
int u = 1;
for(int b = 30;b >= 0;b--){
if((x & (1<<b)) == 0){
if(trie[u].first == 0){
trie[u].first = CNT;
CNT++;
}
u = trie[u].first;
}
else{
if(trie[u].second == 0){
trie[u].second = CNT;
CNT++;
}
u = trie[u].second;
}
S[u].insert(pos);
}
}
int main(){
//freopen("i.txt","r",stdin);
ios_base::sync_with_stdio(false);
cin.tie(0);
int Q; cin >> Q;
queries.push_back(ii(-1,0));
while(Q--){
string s; int a, b;
cin >> s >> a >> b;
if(s[0] == 'A' || s[0] == 'a'){
a--;
assert(a < n);
adj[a].push_back(n);
XOR[n] = XOR[a] ^ b;
queries.push_back(ii(-1,n));
n++;
}
else{
assert(a-1 < n);
assert(b-1 < n);
queries.push_back(ii(a-1,b-1));
}
}
dfs(0);
for(ii q : queries){
//cout << q.first << " " << q.second << "\n";
if(q.first == -1){
int pos = low[q.second];
int x = XOR[q.second];
INS(x, pos);
continue;
}
int other = XOR[q.first];
int L = low[q.second], R = high[q.second];
int cur = 0;
int u = 1;
for(int b = 30;b >= 0;b--){
int pref = trie[u].first;
int nopref = trie[u].second;
if(pref == 0){
cur ^= (1 << b);
u = nopref; continue;
}
if(nopref == 0){
u = pref; continue;
}
if((other & (1<<b)) == 0){
swap(pref, nopref);
cur ^= (1 << b);
}
if(Q <= 2000){
set<int> s = S[pref];
auto it = s.lower_bound(L);
if(it == s.end() || *it > R){
cur ^= (1 << b);
u = nopref;
}
else u = pref;
}
else u = pref;
}
cout << (cur ^ other) << "\n";
}
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
112 ms |
193016 KB |
Output is correct |
2 |
Correct |
106 ms |
193044 KB |
Output is correct |
3 |
Correct |
111 ms |
193144 KB |
Output is correct |
4 |
Correct |
115 ms |
193144 KB |
Output is correct |
5 |
Correct |
107 ms |
193016 KB |
Output is correct |
6 |
Correct |
110 ms |
193016 KB |
Output is correct |
7 |
Correct |
107 ms |
193144 KB |
Output is correct |
8 |
Correct |
109 ms |
193144 KB |
Output is correct |
9 |
Correct |
119 ms |
193016 KB |
Output is correct |
10 |
Correct |
109 ms |
193028 KB |
Output is correct |
11 |
Correct |
112 ms |
193144 KB |
Output is correct |
12 |
Correct |
112 ms |
193272 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
112 ms |
193016 KB |
Output is correct |
2 |
Correct |
106 ms |
193044 KB |
Output is correct |
3 |
Correct |
111 ms |
193144 KB |
Output is correct |
4 |
Correct |
115 ms |
193144 KB |
Output is correct |
5 |
Correct |
107 ms |
193016 KB |
Output is correct |
6 |
Correct |
110 ms |
193016 KB |
Output is correct |
7 |
Correct |
107 ms |
193144 KB |
Output is correct |
8 |
Correct |
109 ms |
193144 KB |
Output is correct |
9 |
Correct |
119 ms |
193016 KB |
Output is correct |
10 |
Correct |
109 ms |
193028 KB |
Output is correct |
11 |
Correct |
112 ms |
193144 KB |
Output is correct |
12 |
Correct |
112 ms |
193272 KB |
Output is correct |
13 |
Correct |
137 ms |
193784 KB |
Output is correct |
14 |
Correct |
134 ms |
194396 KB |
Output is correct |
15 |
Correct |
135 ms |
195064 KB |
Output is correct |
16 |
Correct |
130 ms |
195704 KB |
Output is correct |
17 |
Correct |
133 ms |
193656 KB |
Output is correct |
18 |
Correct |
148 ms |
194296 KB |
Output is correct |
19 |
Correct |
140 ms |
195064 KB |
Output is correct |
20 |
Correct |
135 ms |
195576 KB |
Output is correct |
21 |
Correct |
159 ms |
193760 KB |
Output is correct |
22 |
Correct |
139 ms |
194296 KB |
Output is correct |
23 |
Correct |
141 ms |
194936 KB |
Output is correct |
24 |
Correct |
133 ms |
195576 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Execution timed out |
5085 ms |
209028 KB |
Time limit exceeded |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
112 ms |
193016 KB |
Output is correct |
2 |
Correct |
106 ms |
193044 KB |
Output is correct |
3 |
Correct |
111 ms |
193144 KB |
Output is correct |
4 |
Correct |
115 ms |
193144 KB |
Output is correct |
5 |
Correct |
107 ms |
193016 KB |
Output is correct |
6 |
Correct |
110 ms |
193016 KB |
Output is correct |
7 |
Correct |
107 ms |
193144 KB |
Output is correct |
8 |
Correct |
109 ms |
193144 KB |
Output is correct |
9 |
Correct |
119 ms |
193016 KB |
Output is correct |
10 |
Correct |
109 ms |
193028 KB |
Output is correct |
11 |
Correct |
112 ms |
193144 KB |
Output is correct |
12 |
Correct |
112 ms |
193272 KB |
Output is correct |
13 |
Correct |
137 ms |
193784 KB |
Output is correct |
14 |
Correct |
134 ms |
194396 KB |
Output is correct |
15 |
Correct |
135 ms |
195064 KB |
Output is correct |
16 |
Correct |
130 ms |
195704 KB |
Output is correct |
17 |
Correct |
133 ms |
193656 KB |
Output is correct |
18 |
Correct |
148 ms |
194296 KB |
Output is correct |
19 |
Correct |
140 ms |
195064 KB |
Output is correct |
20 |
Correct |
135 ms |
195576 KB |
Output is correct |
21 |
Correct |
159 ms |
193760 KB |
Output is correct |
22 |
Correct |
139 ms |
194296 KB |
Output is correct |
23 |
Correct |
141 ms |
194936 KB |
Output is correct |
24 |
Correct |
133 ms |
195576 KB |
Output is correct |
25 |
Execution timed out |
5085 ms |
209028 KB |
Time limit exceeded |
26 |
Halted |
0 ms |
0 KB |
- |