Cod sursa(job #1100492)

Utilizator killerkiller11Balas Tudor killerkiller11 Data 6 februarie 2014 22:00:58
Problema Subsecventa de suma maxima Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.72 kb
#include<fstream>
int v[6000005];
int best[6000005];
using namespace std;
int main()
{
    ifstream fin("ssm.in");
    ofstream fout("ssm.out");
    int n,min,bestSum,x;
    fin>>n;
    for(int i=1;i<=n;++i)
        fin>>v[i];
    if(n==1)
    {
        fout<<v[1]<<" 1 1";
        return 0;
    }
    bestSum=v[1];
    int a,b,aa;
    a=0;
    b=0;
    for(int i=1;i<=n;++i)
    {
        best[i]=v[i];
        if(best[i]<best[i-1]+v[i])
            best[i]=best[i-1]+v[i];
        else if(best[i]>best[i-1]+v[i])
            aa=i;
        if(bestSum<best[i])
        {
            bestSum=best[i];
            b=i;
            a=aa;
        }
    }
    fout<<bestSum<<" "<<a<<" "<<b;
    return 0;
}