Cod sursa(job #1641834)

Utilizator QuzuroPrioteasa Andrei Quzuro Data 9 martie 2016 11:06:54
Problema Subsecventa de suma maxima Scor 95
Compilator cpp Status done
Runda Arhiva educationala Marime 0.68 kb
#include <fstream>
using namespace std;
ifstream fin("ssm.in");
ofstream fout("ssm.out");
int i,n,x,smax,stmax,drmax,st,s,s1,dif;
int main()
{
    fin>>n;
    for(i=1;i<=n;i++)
    {
        fin>>x;
        s=s+x;
        s1+=x;
        if(s>smax)
        {
            smax=s;
            drmax=i;
            stmax=st;
            dif=drmax-stmax;
        }
        if(s==smax)
        {
            if(i-st<=dif)
                drmax=i;
        }
        if(s<0)
        {
            s=0;
            st=i+1;
        }
    }
    if(smax==0)
    {
        fout<<s1<<" "<<1<<" "<<n;
    }
    else
    {
       fout<<smax<<" "<<stmax<<" "<<drmax;
    }

}