이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <iostream>
const int N = 2000005;
using namespace std;
typedef long long ll;
int cur;
int cl;
char word[N];
struct Node
{
Node* l;
Node* r;
int sum;
Node()
{
this->sum = 0;
l = nullptr;
r = nullptr;
}
};
Node* root[N];
Node* cons(int a, int b)
{
Node* node = new Node();
if (a == b) return node;
int mid = (a + b) / 2;
node->l = cons(a, mid);
node->r = cons(mid + 1, b);
return node;
}
Node* add(int i, Node* org, int a, int b)
{
Node* node = new Node();
if (a == b)
{
node->sum = 1;
return node;
}
int mid = (a + b) / 2;
if (i <= mid)
{
node->l = add(i, org->l, a, mid);
node->r = org->r;
} else
{
node->l = org->l;
node->r = add(i, org->r, mid + 1, b);
}
node->sum = (node->l)->sum + (node->r)->sum;
//cout << a << " " << b << " " << node->sum << endl;
return node;
}
int kth(Node* node, int i, int a, int b)
{
if (a == b) return a;
int mid = (a + b) / 2;
if (node->l->sum >= i) return kth(node->l, i, a, mid);
i -= node->l->sum;
return kth(node->r, i, mid + 1, b);
}
void Init()
{
root[0] = cons(0, N - 1);
cur = 0;
cl = -1;
}
void TypeLetter(char L) {
cl++;
cur++;
word[cl] = L;
root[cur] = add(cl, root[cur - 1], 0, N - 1);
}
void UndoCommands(int U) {
root[cur + 1] = root[cur - U];
cur++;
}
char GetLetter(int P) {
int i = kth(root[cur], P + 1, 0, N - 1);
return word[kth(root[cur], P + 1, 0, N - 1)];
}
컴파일 시 표준 에러 (stderr) 메시지
scrivener.cpp: In function 'char GetLetter(int)':
scrivener.cpp:102:9: warning: unused variable 'i' [-Wunused-variable]
102 | int i = kth(root[cur], P + 1, 0, N - 1);
| ^
# | 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... |