Submission #484713

#TimeUsernameProblemLanguageResultExecution timeMemory
484713WeissBlumeWall (IOI14_wall)C++17
Compilation error
0 ms0 KiB
#include<cstdio> #include<queue> #include<memory> #include<algorithm> #define x first #define y second using namespace std; using ii = pair<int, int>; int read(int x = 0) { return scanf("%d", &x), x; } template<class node_t> struct LazySegmentTree { using T = typename node_t::val_t; using U = typename node_t::upd_t; unique_ptr<node_t[]> nodes; int size, height; LazySegmentTree(int n): size(1), height(0) { while (size < n || size < 8) size <<= 1, ++height; nodes = unique_ptr<node_t[]>(new node_t[size<<1]); for (int i = size - 1; i > 0; i--) nodes[i].combine(nodes[i<<1], nodes[i<<1|1]); } void update(int _l, int _r, const U& v) { push(_l); push(_r+1); for (int l = _l + size, r = _r + size + 1; l < r; l >>= 1, r >>= 1) { if (l & 1) nodes[l++].update(v); if (r & 1) nodes[--r].update(v); } push(_l); push(_r+1); for (int l = (_l+size) >> 1; l > 0; l >>= 1) nodes[l].combine(nodes[l<<1], nodes[l<<1|1]); for (int r = (_r+size) >> 1; r > 0; r >>= 1) nodes[r].combine(nodes[r<<1], nodes[r<<1|1]); } void push(int p) { for (int s = height; s > 0; s--) _push((p + size) >> s); } void _push(int i) { if (nodes[i].has_lazy()) { nodes[i<<1].update(nodes[i].lazy); nodes[i<<1|1].update(nodes[i].lazy); nodes[i].clear_lazy(); } } T query(int l, int r) { push(l), push(r+1); node_t le, ri, tmp; for (l += size, r += size + 1; l < r; l >>= 1, r >>= 1) { if (l & 1) le = tmp.combine(le, nodes[l++]); if (r & 1) ri = tmp.combine(nodes[--r], ri); } return tmp.combine(le, ri).query(); } }; struct WallNode { constexpr static ii lazy_null {0, 100'000}; using self_t = WallNode; using val_t = int; using upd_t = ii; upd_t lazy{lazy_null}; upd_t v{}; val_t query() const { return v.x; } void update(upd_t a) { if (a.x > v.y) v = ii{a.x, a.x}; if (a.x > lazy.y) lazy = ii{a.x, a.x}; if (a.y < v.x) v = ii{a.y, a.y}; if (a.y < lazy.x) lazy = ii{a.y, a.y}; lazy.x = max(lazy.x, a.x); lazy.y = min(lazy.y, a.y); v.x = max(v.x, a.x); v.y = min(v.y, a.y); } bool has_lazy() const { return lazy != lazy_null; } void clear_lazy() { lazy = lazy_null; } self_t combine(self_t const& le, self_t const& ri) { if (le.v != ii{}) v = le.v; if (ri.v != ii{}) v = ri.v; return *this; } }; int n = read(), m = read(); LazySegmentTree<WallNode> tree(n+2); int main() { for (int l, r, h; m--;) switch(read()) { case 1: { l = read()+1, r = read()+1, h = read(); tree.update(l, r, ii{h, 100'000}); break; } case 2: { l = read()+1, r = read()+1, h = read(); tree.update(l, r, ii{0, h}); break; } default: __builtin_unreachable(); } for (int i = 1; i <= n; i++) printf("%d\n", tree.query(i, i)); return 0; }

Compilation message (stderr)

wall.cpp: In function 'int read(int)':
wall.cpp:9:35: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
    9 | int read(int x = 0) { return scanf("%d", &x), x; }
      |                              ~~~~~^~~~~~~~~~
/usr/bin/ld: /tmp/ccFyaYXs.o: in function `main':
grader.cpp:(.text.startup+0x0): multiple definition of `main'; /tmp/ccst46nr.o:wall.cpp:(.text.startup+0x0): first defined here
/usr/bin/ld: /tmp/ccFyaYXs.o: in function `main':
grader.cpp:(.text.startup+0x133): undefined reference to `buildWall(int, int, int*, int*, int*, int*, int*)'
collect2: error: ld returned 1 exit status