Cod sursa(job #1100452)

Utilizator killerkiller11Balas Tudor killerkiller11 Data 6 februarie 2014 21:38:52
Problema Subsecventa de suma maxima Scor 95
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include<fstream>
int v[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;
    }
    v[0]=0;
    for(int i=1;i<=n;i++)
        v[i]=v[i]+v[i-1];
    min=v[0];
    bestSum=-99999999;
    int a=-99999999,b,mini;
    for(int i=1;i<=n;i++)
    {
        x=v[i]-min;
        if(min>v[i])
        {
            min=v[i];
            mini=i;
        }
        if(bestSum<x || bestSum<x && a!=-99999999 && (i-mini)>(b-a))
        {
            bestSum=x;
            a=mini;
            b=i;
        }
    }
    ++a;
    fout<<bestSum<<" "<<a<<" "<<b;
    return 0;
}