Cod sursa(job #3239261)

Utilizator Cyb3rBoltSbora Ioan-David Cyb3rBolt Data 3 august 2024 18:43:10
Problema SequenceQuery Scor 70
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 2.38 kb
#include <bits/stdc++.h>

using namespace std;
ifstream fin("sequencequery.in");
ofstream fout("sequencequery.out");
#define int long long
int n, q;

struct Iris {
    int suma, prefix, sufix, ans;
    int getMax() {
        bool sum0 = false, pref0 = false, suf0 = false, ans0 = false;
        if(suma == 0) sum0 = true;
        if(prefix == 0) pref0 = true;
        if(sufix == 0) suf0 = true;
        if(ans == 0) ans0 = true;
        int maxim = LONG_MIN;
        if(!sum0) maxim = max(maxim, suma);
        if(!pref0) maxim = max(maxim, prefix);
        if(!suf0) maxim = max(maxim, sufix);
        if(!ans0) maxim = max(maxim, ans);
        return maxim;
    }
}aint[400010];

inline Iris combina(Iris st, Iris dr) {
    Iris ans;
    ans.suma = st.suma + dr.suma;
    ans.prefix = max(st.prefix, st.suma + dr.prefix);
    ans.sufix = max(dr.sufix, dr.suma + st.sufix);
    ans.ans = max(st.sufix + dr.prefix, max(st.ans, dr.ans));
    return ans;
}

inline Iris make_data(int val) {
    Iris aux;
    aux.suma = val;
    aux.prefix = aux.sufix = aux.ans = max(0LL, val);
    return aux;
}

inline void build(int nod, int st, int dr) {
    if(st == dr) {
        int x; fin >> x;
        aint[nod] = make_data(x);
    }
    else {
        int mid = (st + dr) / 2;
        build(2 * nod, st, mid);
        build(2 * nod + 1, mid + 1, dr);
        aint[nod] = combina(aint[2 * nod], aint[2 * nod + 1]);
    }
}

inline void update(int nod, int poz, int st, int dr, int val) {
    if(st == dr) aint[nod] = make_data(val);
    else {
        int mid = (st + dr) / 2;
        if(poz <= mid) update(2 * nod, poz, st, mid, val);
        else update(2 * nod + 1, poz, mid + 1, dr, val);
        aint[nod] = combina(aint[2 * nod], aint[2 * nod + 1]);
    }
}

inline Iris query(int nod, int st, int dr, int a, int b) {
    if(a <= st && dr <= b) return aint[nod];
    else {
        int mid = (st + dr) / 2;
        Iris v1, v2;
        v1 = v2 = make_data(0);
        if(a <= mid) v1 = query(2 * nod, st, mid, a, b);
        if(b >= mid + 1) v2 = query(2 * nod + 1, mid + 1, dr, a, b);
        return combina(v1, v2);
    }
}

signed main()
{
    fin >> n >> q;
    build(1, 1, n);
    while(q--) {
        int st, dr;
        fin >> st >> dr;
        Iris sol = query(1, 1, n, st, dr);
        fout << sol.getMax() << '\n';
    }

    return 0;
}