이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
#include "popa.h"
using namespace std;
static int nxt[2018];
int solve (int l, int r, int *Left, int *Right)
{
    if (l > r) return -1;
    if (l == r)
        return l;
    if (r == l + 1)
    {
        if (nxt[l] > r)
        {
            Right[l] = r;
            return l;
        }
        Left[r] = l;
        return r;
    }
    int pos = l;
    while (nxt[pos] <= r)
        pos = nxt[pos];
    int ras = pos;
    Left[ras] = solve (l, ras - 1, Left, Right);
    Right[ras] = solve (ras + 1, r, Left, Right);
    return ras;
}
int solve (int nn, int* Left, int* Right)
{
    int N = nn;
    for (int i=0; i<N; i++)
        Left[i] = Right[i] = -1;
    nxt[N - 1] = N;
    for (int i=N - 2; i>=0; i--)
    {
        int pos = i + 1;
        while (pos < N && query (i, i, i, pos))
            pos = nxt[pos];
        nxt[i] = pos;
    }
    int root = solve (0, N - 1, Left, Right);
    return root;
}
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... |