#include <bits/stdc++.h>
constexpr int N = 5e4 + 5; int n, m, op, l, r, arr[N];
class SegmentTree { protected: class Values { public: int sum = 0, max = 0, left_max = 0, right_max = 0;
Values() = default;
Values(int x) { sum = x; max = x; left_max = x; right_max = x; } };
class Node { public: int l, r; Values val; };
Node tr[N << 2];
public: Values merge(Values a, Values b) { Values retval;
retval.sum = a.sum + b.sum; retval.max = std::max({a.max, b.max, a.right_max + b.left_max}); retval.left_max = std::max(a.left_max, a.sum + b.left_max); retval.right_max = std::max(b.right_max, b.sum + a.right_max);
return retval; }
void push_up(int k) { Values lc = tr[k << 1].val, rc = tr[k << 1 | 1].val; tr[k].val = merge(lc, rc); }
void build_tree(int k, int l, int r) { tr[k].l = l, tr[k].r = r; tr[k].val = Values(0);
if (tr[k].l == tr[k].r) { tr[k].val = Values(arr[l]); return void(); }
int mid = (tr[k].l + tr[k].r) >> 1; int lc = k << 1, rc = k << 1 | 1;
build_tree(lc, l, mid); build_tree(rc, mid + 1, r);
push_up(k); }
void modify(int k, int pos, int value) { if (tr[k].l == tr[k].r && tr[k].r == pos) { tr[k].val = Values(value); return void(); }
int mid = (tr[k].l + tr[k].r) >> 1; int lc = k << 1, rc = k << 1 | 1;
if (pos <= mid) { modify(lc, pos, value); } else { modify(rc, pos, value); }
push_up(k); }
Values query(int k, int l, int r) { if (tr[k].l >= l && tr[k].r <= r) { return tr[k].val; }
int mid = (tr[k].l + tr[k].r) >> 1; int lc = k << 1, rc = k << 1 | 1;
if (r <= mid) { return query(lc, l, r); } else if (l > mid) { return query(rc, l, r); } else { return merge(query(lc, l, mid), query(rc, mid + 1, r)); } } } segment_tree;
int main() { std::ios::sync_with_stdio(false); std::cin.tie(nullptr); std::cout.tie(nullptr);
std::cin >> n;
for (int i = 1; i <= n; i++) { std::cin >> arr[i]; }
segment_tree.build_tree(1, 1, n); std::cin >> m;
while (m--) { std::cin >> op >> l >> r; if (op == 0) { segment_tree.modify(1, l, r); } else if (op == 1) { std::cout << segment_tree.query(1, l, r).max << '\n'; } }
return 0; }
|