#include #include using namespace std; using namespace atcoder; using ll = long long; int main(){ cin.tie(nullptr); ios_base::sync_with_stdio(false); /* 平面走査でやる。 L_i-1のところで- R_iのところで+する。 縦方向はfenwick treeで */ ll N, Q, L, R; cin >> N >> Q; vector A(N), B; for (int i=0; i> A[i]; vector>> v(N+1); //横方向ごとにクエリインデックス、+か-か vector ans(Q), X(Q); for (int i=0; i> L >> R >> X[i]; v[L-1].push_back({i, -1}); v[R].push_back({i, 1}); } B = A; sort(B.begin(), B.end()); B.erase(unique(B.begin(), B.end()), B.end()); fenwick_tree tc(N+1), ts(N+1); for (int i=0; i<=N; i++){ if (i){ ll z = lower_bound(B.begin(), B.end(), A[i-1])-B.begin(); tc.add(z, 1); ts.add(z, A[i-1]); } for (auto [idx, sign] : v[i]){ ll x = X[idx], z = upper_bound(B.begin(), B.end(), x)-B.begin(); ll c1 = tc.sum(0, z), c2 = tc.sum(z, N+1), s1 = ts.sum(0, z), s2 = ts.sum(z, N+1); ans[idx] += sign * (c1*x-s1+s2-c2*x); } } for (int i=0; i