Cod sursa(job #361240)

Utilizator DeadEyeNaiba Mihai Lucian DeadEye Data 4 noiembrie 2009 11:51:28
Problema Subsecventa de suma maxima Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.42 kb
#include<cstdio>
int a[6000001];
int main()
{
	int n,i,s,k,p1,p2,max;
	freopen("ssm.in","r",stdin);
	freopen("ssm.out","w",stdout);
	scanf("%d",&n);
	for(i=1;i<=n;++i)
	{
		scanf("%d",&a[i]);
	}
	s=a[1]; k=1; p1=1; p2=1;
	max=a[1];
	for(i=2;i<=n;++i)
	{
		s+=a[i];
		if(s>max)
		{
			max=s;
			p1=k;
			p2=i;
		}
		if(s<0)
		{
			s=0;
			k=i+1;
		}
	}
	printf("%d %d %d\n",max,p1,p2);
	return 0;
}