이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define DEBUG 0
using namespace std;
const int N = 2e5 + 10;
int a[N];
long long S, T;
class A {
public :
int leftmost, rightmost;
long long windtemp;
A() {}
A(const int &l, const int &r, const long long &w) : leftmost(l), rightmost(r), windtemp(w) {}
A operator+(const A &o) const {
int l, r;
long long w;
l = leftmost;
r = o.rightmost;
w = windtemp + o.windtemp;
if(rightmost < o.leftmost) {
w -= S * (o.leftmost - rightmost);
}
else {
w += T * (rightmost - o.leftmost);
}
return A(l, r, w);
}
};
class SegmentTree {
private :
A tree[4 * N];
long long lazy[4 * N];
public :
void build(const int &idx, const int &l, const int &r) {
if(l == r) {
tree[idx] = A(a[l], a[l], 0);
return;
}
int mid = (l + r) / 2;
build(idx * 2, l, mid);
build(idx * 2 + 1, mid + 1, r);
tree[idx] = tree[idx * 2] + tree[idx * 2 + 1];
}
void push(const int &idx, const int &l, const int &r) {
if(lazy[idx] == 0) {
return;
}
tree[idx].leftmost += lazy[idx];
tree[idx].rightmost += lazy[idx];
if(l != r) {
lazy[idx * 2] += lazy[idx];
lazy[idx * 2 + 1] += lazy[idx];
}
lazy[idx] = 0;
}
void update(const int &idx, const int &l, const int &r, const int &ql, const int &qr, const int &x) {
push(idx, l, r);
if(r < ql or qr < l) {
return;
}
if(ql <= l and r <= qr) {
lazy[idx] += x;
push(idx, l, r);
return;
}
int mid = (l + r) / 2;
update(idx * 2, l, mid, ql, qr, x);
update(idx * 2 + 1, mid + 1, r, ql, qr, x);
tree[idx] = tree[idx * 2] + tree[idx * 2 + 1];
}
long long get_ans() {
return tree[1].windtemp;
}
}ST;
int main() {
cin.tie(0)->sync_with_stdio(0);
int n, q;
cin >> n >> q >> S >> T;
for(int i = 0; i <= n; i++) {
cin >> a[i];
}
ST.build(1, 0, n);
while(q--) {
int l, r, x;
cin >> l >> r >> x;
ST.update(1, 0, n, l, r, x);
cout << ST.get_ans() << '\n';
}
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... |