Submission #716065

#TimeUsernameProblemLanguageResultExecution timeMemory
716065schiftyfive4Rainforest Jumps (APIO21_jumps)C++14
Compilation error
0 ms0 KiB
#include "jumps.h" #include <bits/stdc++.h> using namespace std; #ifdef LOCAL #include "debug.hpp" #else #define debug(...) "MJ >> LAMELO" #endif template <typename T, class F = function<T(const T&, const T&)>> struct sparse_table { int n; vector<vector<T>> mat; F func; sparse_table() {} sparse_table(const vector<T>& a, const F& f) : func(f) { n = static_cast<int>(a.size()); int max_log = 32 - __builtin_clz(n); mat.resize(max_log); mat[0] = a; for (int j = 1; j < max_log; j++) { mat[j].resize(n - (1 << j) + 1); for (int i = 0; i <= n - (1 << j); i++) { mat[j][i] = func(mat[j - 1][i], mat[j - 1][i + (1 << (j - 1))]); } } } T get(int L, int R) const { assert(0 <= L && L <= R && R <= n - 1); int lg = 32 - __builtin_clz(R - L + 1) - 1; return func(mat[lg][L], mat[lg][R - (1 << lg) + 1]); } }; const int lg = 20; vector<int> h; vector<vector<int>> g; vector<vector<int>> go_low; vector<vector<int>> go_high; sparse_table st; void init(int n, vector<int> H) { h = H; g.resize(n + 1); vector<int> t; for (int i = 0; i < n; i++) { while (!t.empty() && h[i] > h[t.back()]) { t.pop_back(); } if (!t.empty()) { g[i].push_back(t.back()); } t.push_back(i); } t.clear(); for (int i = n - 1; i >= 0; i--) { while (!t.empty() && h[i] > h[t.back()]) { t.pop_back(); } if (!t.empty()) { g[i].push_back(t.back()); } t.push_back(i); } for (int i = 0; i < n; i++) { if (g[i].size() == 2 && h[g[i][0]] > h[g[i][1]]) { swap(g[i][0], g[i][1]); } } go_low = vector<vector<int>>(n + 1, vector<int>(lg)); go_high = vector<vector<int>>(n + 1, vector<int>(lg)); for (int i = 0; i <= n; i++) { go_low[i][0] = go_high[i][0] = n; if (g[i].size() > 0) { go_low[i][0] = g[i][0]; } if (g[i].size() > 1){ go_high[i][0] = g[i][1]; } } for (int b = 1; b < lg; b++) { for (int i = 0; i <= n; i++) { go_low[i][b] = go_low[go_low[i][b - 1]][b - 1]; go_high[i][b] = go_high[go_high[i][b - 1]][b - 1]; } } vector<int> p(n); iota(p.begin(), p.end(), 0); st(p, [&](int i, int j) { return h[i] > h[j] ? i : j; }); } int minimum_jumps(int a, int b, int c, int d) { int x = st.get(c, d); if (h[st.get(b, c - 1)] > h[x]) { return -1; } int l = a; int r = b; while (l < r) { int mid = (l + r) >> 1; int pos = st.get(mid, b); if (h[pos] > h[x]) { l = mid + 1; } else { r = mid; } } int s = st.get(l, b); int ans = 0; for (int b = lg - 1; b >= 0; b--) { if (go_high[s][b] <= x) { s = go_high[s][b]; ans += (1 << b); } } for (int b = lg - 1; b >= 0; b--) { if (go_low[s][b] <= x) { s = go_low[s][b]; ans += (1 << b); } } return ans; }

Compilation message (stderr)

jumps.cpp:41:1: error: invalid use of template-name 'sparse_table' without an argument list
   41 | sparse_table st;
      | ^~~~~~~~~~~~
jumps.cpp:41:1: note: class template argument deduction is only available with '-std=c++17' or '-std=gnu++17'
jumps.cpp:12:8: note: 'template<class T, class F> struct sparse_table' declared here
   12 | struct sparse_table {
      |        ^~~~~~~~~~~~
jumps.cpp: In function 'void init(int, std::vector<int>)':
jumps.cpp:90:3: error: 'st' was not declared in this scope; did you mean 't'?
   90 |   st(p, [&](int i, int j) { return h[i] > h[j] ? i : j; });
      |   ^~
      |   t
jumps.cpp: In function 'int minimum_jumps(int, int, int, int)':
jumps.cpp:94:11: error: 'st' was not declared in this scope; did you mean 'std'?
   94 |   int x = st.get(c, d);
      |           ^~
      |           std