Cod sursa(job #1336049)

Utilizator GeorgianBaditaBadita Marin-Georgian GeorgianBadita Data 6 februarie 2015 14:34:16
Problema Subsecventa de suma maxima Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.64 kb
#include <fstream>
using namespace std;
ifstream f("ssm.in");
ofstream g("ssm.out");
int v[6000001];
int main()
{
    int n;
    f >> n;
    f >> v[1];
    for(int i = 2; i<=n; i++)
        f >> v[i];
    int start = 1, stop = 1, smax = v[1], s = v[1], last = 1;
    if(s < 0)
    {
        s = 0;
        last = 2;
    }
    for(int i = 2; i<=n; i++)
    {
        s += v[i];
        if(s > smax)
        {
            smax = s;
            start = last;
            stop = i;
        }
        if(s < 0)
        {
            s = 0;
            last = i + 1;
        }
    }
    g << smax << ' ' << start << ' ' << stop;
}