| # | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 | 
|---|---|---|---|---|---|---|---|
| 1191843 | LolkasMeep | 크레이피쉬 글쓰는 기계 (IOI12_scrivener) | C++20 | 0 ms | 0 KiB | 
#include "bits/stdc++.h"
using namespace std;
struct Try{
    Try* parent = NULL;
    Try *children[26] = {NULL};
    char chr;
    Try(char c, Try* p){
        parent = p;
        chr = c;
    }
    Try* add(char c){
        if(children[c-'a'] != NULL) return children[c-'a'];
        children[c-'a'] = new Try(c, this);
        return children[c-'a'];
    }
    string get(){
        if(parent == NULL) return chr;
        return parent->get() + chr;
    }
}
int i=1;
Try *tries[1000005];
void Init(){
    tries[0] = NULL;
};
void TypeLetter(char L){
    tries[i]=Try(L, tries[i-1]);
    i++;
}
void UndoCommands(int U){
    tries[i]=Try(L, tries[i-U-1]);
    i++;
}
char GetLetter(int P){
    return tries[i-1]->get()[P]
}
