Cod sursa(job #2869609)

Utilizator LiviuInfoPrioteasa Liviu LiviuInfo Data 11 martie 2022 18:08:02
Problema Subsecventa de suma maxima Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.62 kb
#include <fstream>
#define DIM 6000010
using namespace std;

ifstream fin("ssm.in");
ofstream fout("ssm.out");

int n, l=1, r=1;
int v[DIM], s[DIM];

int main()
{
    fin >> n;
    for (int i = 1; i <= n; i++)
        fin >> v[i];

    s[1] = v[1];
    for (int i = 2; i <= n; i++)
    {
        s[i] = s[i-1] + v[i];
        for (int j = l; j <= r; j++)
        {
            if (s[i] - s[j - 1] > s[i] - s[l - 1])
            {
                l = j;
                r = i;
            }
                
        }
    }

    fout << s[r] - s[l - 1] << " " << l << " " << r << " ";
    return 0;
}