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 <bits/stdc++.h>
using namespace std;
#include "wall.h"
struct node {
int small = 0, large = 1e9;
void upd(int op, int h) {
if (op == 1) {
// min
small = max(small, h);
large = max(large, h);
} else {
// max
small = min(small, h);
large = min(large, h);
}
}
};
node st[(1 << 22)];
void down(int p, int i, int j) {
if (i == j) return;
st[p*2].small = max(st[p].small, min(st[p*2].small, st[p].large));
st[p*2].large = min(st[p].large, max(st[p*2].large, st[p].small));
st[p*2+1].small = max(st[p].small, min(st[p*2+1].small, st[p].large));
st[p*2+1].large = min(st[p].large, max(st[p*2+1].large, st[p].small));
st[p].small = 0; st[p].large = 1e9;
}
void upd(int p, int i, int j, int l, int r, int op, int h) {
down(p, i, j);
if (i > r || j < l) return;
if (l <= i && j <= r) {
st[p].upd(op, h);
return;
}
upd(p*2, i, (i+j)/2, l, r, op, h);
upd(p*2+1, (i+j)/2+1, j, l, r, op, h);
}
int qry(int p, int i, int j, int x) {
down(p, i, j);
if (i == j && i == x) {
return st[p].small;
}
if ((i+j)/2 >= x) return qry(p*2, i, (i+j)/2, x);
return qry(p*2+1, (i+j)/2+1, j, x);
}
void buildWall(int n, int k, int op[], int left[], int right[], int height[], int finalHeight[]) {
for (int i = 0; i < k; i++) {
upd(1, 0, n-1, left[i], right[i], op[i], height[i]);
}
for (int i = 0; i < n; i++) {
finalHeight[i] = qry(1, 0, n-1, i);
}
}
# | 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... |