# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
829489 | rainboy | Curtains (NOI23_curtains) | C11 | 196 ms | 13684 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <stdio.h>
#define N 500000
#define SMALL 2000
#define M 500000
int min(int a, int b) { return a < b ? a : b; }
int main() {
static int ll[N], qu[N];
int n, m, q, cnt, l, r;
scanf("%d%d%d", &n, &m, &q);
if (n <= SMALL) {
static char has[SMALL][SMALL], can[SMALL][SMALL];
while (m--) {
scanf("%d%d", &l, &r), l--, r--;
has[l][r] = 1;
}
for (r = 0; r < n; r++)
ll[r] = r + 1;
for (l = n - 1; l >= 0; l--) {
for (r = l; r < n; r++)
if (has[l][r])
ll[r] = l;
cnt = 0;
for (r = l; r < n; r++) {
qu[cnt++] = r;
while (cnt && qu[cnt - 1] >= ll[r])
cnt--;
can[l][r] = cnt == 0;
}
}
while (q--) {
scanf("%d%d", &l, &r), l--, r--;
printf(can[l][r] ? "YES\n" : "NO\n");
}
} else {
static char can[N];
for (r = 0; r < n; r++)
ll[r] = r + 1;
while (m--) {
scanf("%d%d", &l, &r), l--, r--;
ll[r] = min(ll[r], l);
}
cnt = 0;
for (r = 0; r < n; r++) {
qu[cnt++] = r;
while (cnt && qu[cnt - 1] >= ll[r])
cnt--;
can[r] = cnt == 0;
}
while (q--) {
scanf("%d%d", &l, &r), l--, r--;
printf(can[r] ? "YES\n" : "NO\n");
}
}
return 0;
}
Compilation message (stderr)
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |