# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
1144880 | akamizane | Wall (IOI14_wall) | C++20 | 0 ms | 0 KiB |
#include<bits/stdc++.h>
using namespace std;
struct Node{
int mi = 0, mx = 1e9;
};
Node t[4 * maxn];
int ans[maxn];
void apply (int id, int mi, int mx){
if (0 <= id && id < 4 * maxn){
t[id].mi = max(t[id].mi, mi);
t[id].mx = min(t[id].mx, mx);
t[id].mi = min(t[id].mi, mx);
t[id].mx = max(t[id].mx, mi);
}
}
void update(int id, int l, int r, int u, int v, int mode, int val){
if (r < u || v < l) return;
if (u <= l && r <= v){
if (mode){
t[id].mx = min(t[id].mx, val);
t[id].mi = min(t[id].mi, val);
}
else{
t[id].mx = max(t[id].mx, val);
t[id].mi = max(t[id].mi, val);
}
return;
}
apply(id << 1, t[id].mi, t[id].mx);
apply(id << 1 | 1, t[id].mi, t[id].mx);
int mid = (l + r) / 2;
t[id] = {0, (int)1e9};
update(id << 1, l, mid, u, v, mode, val);
update(id << 1 | 1, mid + 1, r, u, v, mode, val);
}
void get(int id, int l, int r){
if (l == r){
ans[l] = min(t[id].mi, t[id].mx);
return;
}
int mid = (l + r) / 2;
apply(id << 1, t[id].mi, t[id].mx);
apply(id << 1 | 1, t[id].mi, t[id].mx);
get(id << 1, l, mid);
get(id << 1 | 1, mid + 1, r);
}
void buildWall(int n, int k, int op[], int left[], int right[], int height[],
int final_height[]) {
for (int i = 0; i < k; i++) {
update(1, 0, n - 1, left[i], right[i], op[i] - 1, height[i]);
}
get(1, 0, n - 1);
for (int i = 0; i < n; i++) final_height[i] = ans[i];
}