이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#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;
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;
l[k]=l[k-1]+1;
p[node][0]=temp;
for(int i=1;i<=21;i++)
p[node][i]=p[p[node][i-1]][i-1];
// cout<<node<<' '<<l[k]<<' '<<L<<endl;
k++;
}
void UndoCommands(int U)
{
node=a[k-U-1];
l[k]=l[k-U-1];
a[k]=node;
// cout<<a[k]<<' '<<l[k]<<endl;
k++;
}
char GetLetter(int P)
{
P=l[k-1]-P-1;
// cout<<P<<endl;
nd=node;
for(int i=21;i>=0;i--)
{
if(P&(1<<i))
nd=p[nd][i];
}
return letter[nd];
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |