#include <bits/stdc++.h>
using namespace std;
const int N=1e6+55;
int trie[N*2][26];
char letter[N];
int p[N][22];
int a[N];
int l[N];
int node;
int cnt=1;
int k=0;
void Init()
{
node=cnt++;
memset(trie,-1,sizeof trie);
}
int c,temp,nd;
void TypeLetter(char L)
{
c=L-'a';
temp=node;
if(trie[node][c]==-1)
trie[node][c]=cnt++;
node=trie[node][c];
letter[node]=L;
a[k]=node;
if(k!=0)
l[k]=l[k-1]+1;
else
l[k]=1;
if(p[node][0]==0)
{
p[node][0]=temp;
// for(int i=1;i<21;i++)
// {
// p[node][i]=p[p[node][i-1]][i-1];
// if(p[node][i]==0)
// break;
// }
}
k++;
}
void UndoCommands(int U)
{
node=a[k-U-1];
l[k]=l[k-U-1];
a[k]=node;
k++;
}
char GetLetter(int P)
{
P=l[k-1]-P-1;
nd=node;
while(P--)
nd=p[nd][0];
//for(int i=20;i>=0;i--)
//{
//if((P&(1<<i)))
// nd=p[nd][i];
//}
return letter[nd];
}
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
189 ms |
203896 KB |
Output is correct |
2 |
Correct |
161 ms |
203896 KB |
Output is correct |
3 |
Correct |
169 ms |
203940 KB |
Output is correct |
4 |
Correct |
172 ms |
204172 KB |
Output is correct |
5 |
Correct |
169 ms |
204172 KB |
Output is correct |
6 |
Correct |
179 ms |
204172 KB |
Output is correct |
7 |
Correct |
169 ms |
204284 KB |
Output is correct |
8 |
Correct |
174 ms |
204284 KB |
Output is correct |
9 |
Correct |
171 ms |
204284 KB |
Output is correct |
10 |
Correct |
177 ms |
204284 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
170 ms |
204284 KB |
Output is correct |
2 |
Correct |
172 ms |
204284 KB |
Output is correct |
3 |
Correct |
225 ms |
204284 KB |
Output is correct |
4 |
Correct |
169 ms |
204284 KB |
Output is correct |
5 |
Correct |
154 ms |
204284 KB |
Output is correct |
6 |
Correct |
169 ms |
204300 KB |
Output is correct |
7 |
Correct |
172 ms |
204300 KB |
Output is correct |
8 |
Correct |
172 ms |
204300 KB |
Output is correct |
9 |
Correct |
164 ms |
204300 KB |
Output is correct |
10 |
Correct |
162 ms |
204300 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
165 ms |
204596 KB |
Output is correct |
2 |
Correct |
171 ms |
204596 KB |
Output is correct |
3 |
Correct |
182 ms |
204596 KB |
Output is correct |
4 |
Correct |
179 ms |
204596 KB |
Output is correct |
5 |
Correct |
186 ms |
204596 KB |
Output is correct |
6 |
Correct |
184 ms |
204752 KB |
Output is correct |
7 |
Correct |
167 ms |
204752 KB |
Output is correct |
8 |
Correct |
163 ms |
204752 KB |
Output is correct |
9 |
Correct |
191 ms |
204752 KB |
Output is correct |
10 |
Correct |
177 ms |
204752 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Execution timed out |
1089 ms |
262068 KB |
Time limit exceeded |
2 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Execution timed out |
1100 ms |
262068 KB |
Time limit exceeded |
2 |
Halted |
0 ms |
0 KB |
- |