#include <iostream>
#include <cstdio>
#include <vector>
#include <array>
#include <string>
#include <algorithm>
#include <numeric>
#include <map>
#include <unordered_map>
#include <set>
#include <unordered_set>
#include <queue>
#include <cmath>
#include <climits>
#include <iomanip>
#include <limits>
#include <tuple>
#include <stack>
#include <bitset>
#include <cstring>
#include <sstream>
#include <functional>
#include <random>
#include <memory>
using namespace std;
using ll = long long;
const ll mN = LLONG_MIN;
int n, q;
vector<ll> a;
struct mst {
int n;
vector<int> st, len;
vector<int> svi;
vector<ll> val;
vector<int> comp;
mst(const vector<ll>& a) {
n = a.size();
val = a;
sort(val.begin(), val.end());
val.erase(unique(val.begin(), val.end()), val.end());
comp.resize(n);
for (int i = 0; i < n; i++) {
comp[i] = lower_bound(val.begin(), val.end(), a[i]) - val.begin();
}
st.assign(4 * n, 0);
len.assign(4 * n, 0);
svi.reserve((size_t)21 * n);
build(1, 0, n - 1);
}
void build(int u, int l, int r) {
if (l == r) {
st[u] = (int)svi.size();
len[u] = 1;
svi.push_back(comp[l]);
return;
}
int mid = (l + r) / 2;
build(2 * u, l, mid);
build(2 * u + 1, mid + 1, r);
int ls = st[u * 2], ln = len[u * 2];
int rs = st[u * 2 + 1], rn = len[u * 2 + 1];
st[u] = (int)svi.size();
len[u] = ln + rn;
svi.resize(svi.size() + len[u]);
int i = 0, j = 0, k = 0;
while (i < ln && j < rn) {
if (svi[ls + i] <= svi[rs + j]) {
svi[st[u] + k++] = svi[ls + i++];
}
else {
svi[st[u] + k++] = svi[rs + j++];
}
}
while (i < ln) {
svi[st[u] + k++] = svi[ls + i++];
}
while (j < rn) {
svi[st[u] + k++] = svi[rs + j++];
}
}
int query_id(int l, int r, int x) {
int idx = -1;
qid(1, 0, n - 1, l, r, x, idx);
return idx;
}
void qid(int u, int l, int r, int ql, int qr, int x, int& idx) {
if (ql > r || qr < l) {
return;
}
if (ql <= l && r <= qr) {
const int* b = svi.data() + st[u];
int m = len[u];
int pos = lower_bound(b, b + m, x) - b;
if (pos > 0) {
idx = max(idx, b[pos - 1]);
}
return;
}
int mid = (l + r) / 2;
qid(u * 2, l, mid, ql, qr, x, idx);
qid(u * 2 + 1, mid + 1, r, ql, qr, x, idx);
}
ll query(int l, int r, ll k) {
int x = lower_bound(val.begin(), val.end(), k) - val.begin();
int idx = query_id(l, r, x);
if (idx == -1) {
return mN;
}
return val[idx];
}
};
mst* MST = nullptr;
struct Node {
ll k, mx;
int l, r;
bool f;
};
struct SS {
ll k, mx;
};
vector<SS> seg;
Node merge(const Node& a, const Node& b) {
if (a.f) {
return b;
}
if (b.f) {
return a;
}
Node r;
r.f = false;
r.l = a.l;
r.r = b.r;
r.mx = max(a.mx, b.mx);
ll c = mN;
int yid = MST->query_id(b.l, b.r, (int)a.mx);
if (yid != -1) {
c = MST->val[(int)a.mx] + MST->val[yid];
}
r.k = max({ a.k, b.k, c });
return r;
}
void build(int u, int l, int r) {
if (l == r) {
seg[u].mx = MST->comp[l];
seg[u].k = 0;
return;
}
int mid = (l + r) / 2;
build(2 * u, l, mid);
build(2 * u + 1, mid + 1, r);
Node A{ seg[2 * u].k, seg[2 * u].mx, l, mid, false };
Node B{ seg[2 * u + 1].k, seg[2 * u + 1].mx, mid + 1, r, false };
Node C = merge(A, B);
seg[u].k = C.k;
seg[u].mx = C.mx;
}
Node query(int u, int l, int r, int ql, int qr) {
if (r < ql || l > qr) {
return { mN, mN, 0, -1, true };
}
if (ql <= l && r <= qr) {
return { seg[u].k, seg[u].mx, l, r, false };
}
int mid = (l + r) >> 1;
Node L = query(2 * u, l, mid, ql, qr);
Node R = query(2 * u + 1, mid + 1, r, ql, qr);
return merge(L, R);
}
void solve() {
cin >> n >> q;
a.resize(n);
for (int i = 0; i < n; ++i) {
cin >> a[i];
}
mst mmm(a);
MST = &mmm;
seg.assign(4 * n, { 0, 0 });
build(1, 0, n - 1);
string out;
out.reserve((size_t)q * 2);
while (q--) {
int l, r;
ll k;
cin >> l >> r >> k;
--l, --r;
Node qr = query(1, 0, n - 1, l, r);
if (qr.k == mN || k < qr.k) {
out.push_back('0');
out.push_back('\n');
}
else {
out.push_back('1');
out.push_back('\n');
}
}
cout << out;
}
signed main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
solve();
return 0;
}
| # | 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... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |