Cod sursa(job #2704523)

Utilizator ParutixLungeanu Razvan Parutix Data 10 februarie 2021 18:53:17
Problema Subsecventa de suma maxima Scor 95
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.77 kb
#include <iostream>
#include <fstream>

using namespace std;

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

int n, x;
int iStart, iEnd, idx;

int main()
{
    bool nrPoz = false;
    int i;
    int sumMax = -2000000001;
    long long sum = 0;
    fin >> n;
    for(i = 1; i <= n; ++i)
    {
        fin >> x;
        if(x > 0) nrPoz = true;
        if(sum < 0)
        {
            idx = i;
            sum = x;
        }
        else
            sum += x;
        if(sum > sumMax)
        {
            sumMax = sum;
            iStart = idx;
            iEnd = i;
        }
    }
    if(nrPoz == true)
        fout << sumMax << " " << iStart << " " << iEnd;
    else fout << "0";

    fin.close();
    fout.close();
    return 0;
}