This documentation is automatically generated by online-judge-tools/verification-helper
View the Project on GitHub ngthanhtrung23/ACM_Notebook_new
#define PROBLEM "https://judge.yosupo.jp/problem/staticrmq" #include <bits/stdc++.h> using namespace std; #include "../RMQ.h" #include "../../buffered_reader.h" #define REP(i, a) for (int i = 0, _##i = (a); i < _##i; ++i) int32_t main() { ios::sync_with_stdio(0); cin.tie(0); int n, q; cin >> n >> q; vector<int> a(n); REP(i,n) cin >> a[i]; RMQ<int, _min> st(a); while (q--) { int l, r; cin >> l >> r; cout << st.get(l, r) << '\n'; } return 0; }
#line 1 "DataStructure/test/rmq.test.cpp" #define PROBLEM "https://judge.yosupo.jp/problem/staticrmq" #include <bits/stdc++.h> using namespace std; #line 1 "DataStructure/RMQ.h" // RMQ {{{ // // Sparse table // Usage: // RMQ<int, _min> st(v); // // Note: // - doesn't work for empty range // // Tested: // - https://judge.yosupo.jp/problem/staticrmq template<class T, T (*op) (T, T)> struct RMQ { RMQ() = default; RMQ(const vector<T>& v) : t{v}, n{(int) v.size()} { for (int k = 1; (1<<k) <= n; ++k) { t.emplace_back(n - (1<<k) + 1); for (int i = 0; i + (1<<k) <= n; ++i) { t[k][i] = op(t[k-1][i], t[k-1][i + (1<<(k-1))]); } } } // get range [l, r-1] // doesn't work for empty range T get(int l, int r) const { assert(0 <= l && l < r && r <= n); int k = __lg(r - l); return op(t[k][l], t[k][r - (1<<k)]); } private: vector<vector<T>> t; int n; }; template<class T> T _min(T a, T b) { return b < a ? b : a; } template<class T> T _max(T a, T b) { return a < b ? b : a; } // }}} #line 1 "buffered_reader.h" // Buffered reader {{{ namespace IO { const int BUFSIZE = 1<<14; char buf[BUFSIZE + 1], *inp = buf; bool reacheof; char get_char() { if (!*inp && !reacheof) { memset(buf, 0, sizeof buf); int tmp = fread(buf, 1, BUFSIZE, stdin); if (tmp != BUFSIZE) reacheof = true; inp = buf; } return *inp++; } template<typename T> T get() { int neg = 0; T res = 0; char c = get_char(); while (!std::isdigit(c) && c != '-' && c != '+') c = get_char(); if (c == '+') { neg = 0; } else if (c == '-') { neg = 1; } else res = c - '0'; c = get_char(); while (std::isdigit(c)) { res = res * 10 + (c - '0'); c = get_char(); } return neg ? -res : res; } }; // Helper methods int ri() { return IO::get<int>(); } // }}} #line 8 "DataStructure/test/rmq.test.cpp" #define REP(i, a) for (int i = 0, _##i = (a); i < _##i; ++i) int32_t main() { ios::sync_with_stdio(0); cin.tie(0); int n, q; cin >> n >> q; vector<int> a(n); REP(i,n) cin >> a[i]; RMQ<int, _min> st(a); while (q--) { int l, r; cin >> l >> r; cout << st.get(l, r) << '\n'; } return 0; }