Cod sursa(job #516310)
| Utilizator | Data | 23 decembrie 2010 18:29:06 | |
|---|---|---|---|
| Problema | Subsecventa de suma maxima | Scor | 80 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.45 kb |
#include<stdio.h>
int main()
{long n,i,j=1,max=-100000,k=1,s=0,b=0,j1=1;
int t;
freopen("ssm.in","r",stdin);
freopen("ssm.out","w",stdout);
scanf("%ld\n",&n);
for(i=1;i<=n;i++)
{scanf("%d",&t);
if(b>s)
{b=s;
j1=i;}
s+=t;
if(max<s-b)
{max=s-b;
k=i;
if(j1<=k)
j=j1;}}
printf("%d %ld %ld\n",max,j,k);
fclose(stdin);
fclose(stdout);
return 0;}
