제출 #61247

#제출 시각아이디문제언어결과실행 시간메모리
61247SpaimaCarpatilorpopa (BOI18_popa)C++17
100 / 100
137 ms640 KiB
#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 timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...