Cod sursa(job #1625649)

Utilizator edi_laitinLaitin Eduard edi_laitin Data 2 martie 2016 20:02:30
Problema Subsecventa de suma maxima Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.82 kb
#include <fstream>
using namespace std;

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

const int NMax = 6000005;
int N,X[NMax],Sum;
int Sol=-2000000000,Start,Finish;

void Read()
{
    fin>>N;
    for(int i = 1; i <= N; ++i)
        fin>>X[i];
}

void Solve()
{
    int Begin = 1;

    for(int i = 1; i <= N; ++i)
    {
        if(X[i] + Sum >= X[i])
            {
                Sum = X[i] + Sum;
            }
        else
            {
                Begin = i;
                Sum = X[i];
            }
        if(Sum > Sol)
            {
                Sol = Sum;
                Start = Begin;
                Finish = i;
            }
    }
}

void Print()
{
    fout<<Sol<<" "<<Start<<" "<<Finish<<"\n";
}

int main()
{
    Read();
    Solve();
    Print();
    return 0;
}