Cod sursa(job #1188428)
Utilizator | Preda Armand armandpreda | Data | 19 mai 2014 18:00:45 |
---|---|---|---|
Problema | Subsecventa de suma maxima | Scor | 95 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.67 kb |
#include <cstdio>
#define LIM 6000000
using namespace std;
int v[LIM+10];
int main()
{
freopen("ssm.in","r",stdin);
freopen("ssm.out","w",stdout);
int n,i,s=0,st=1,dr=1,smax,stmax=1,drmax=1;
scanf("%d",&n);
for(i=1;i<=n;++i)
scanf("%d",v+i);
s=smax=v[1];
for(i=2;i<=n;++i)
if(s+v[i]>=v[i])
{
s=s+v[i];
dr=i;
if(s>smax)
{
smax=s;
stmax=st;
drmax=dr;
}
}
else
{
st=dr=i;
s=v[i];
}
printf("%d %d %d",smax,stmax,drmax);
return 0;
}