Cod sursa(job #1414785)

Utilizator MailatMailat Radu Mailat Data 3 aprilie 2015 00:05:50
Problema Subsecventa de suma maxima Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.64 kb
#include <fstream>
#include <limits>
using namespace std;

#define MAXN 6000001

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

int S[MAXN];

int main()
{
    int n;
    fin >> n;

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

    int bestSum = numeric_limits<int>::min();
    int sum = 0, beg, end, idx;

    for(int i = 1; i <= n; i++)
    {
        if(sum < 0)
            sum = S[i], idx = i;
        else
            sum += S[i];
        if(bestSum < sum)
            bestSum = sum, beg = idx, end = i;
    }
    fout << bestSum << " " << beg << " " << end;
    fout << '\n';

    return 0;
}