Cod sursa(job #528783)

Utilizator Catah15Catalin Haidau Catah15 Data 3 februarie 2011 14:23:03
Problema Subsecventa de suma maxima Scor 70
Compilator cpp Status done
Runda Arhiva educationala Marime 0.64 kb
#include <fstream>
#define MAXN 6000010
using namespace std;

int sum[MAXN], best[MAXN], a[MAXN], n, bestSum;

int main()
{
	ifstream f("ssm.in");
	ofstream g("ssm.out");
	
	f >> n;
	
	sum[0] = 0;
	
	for(int i = 1; i <= n; ++i)
	{
		f >> a[i];
		
		sum[i] = sum[i - 1] + a[i];
	}
	
	int min = 0, pozi = 0, pozf = 0;
	
	for(int i = 1; i <= n; ++i)
	{
		best[i] = sum[i] - min;
		
		if(sum[i] < min)
		{	
			min = sum[i];
			pozi = i;
		}
			
		if(best[i] > bestSum)
		{
			bestSum = best[i];
			pozf = i;
		}
		
	}
	
	g << bestSum << " " << pozi + 1 << " " << pozf;
	
	f.close();
	g.close();
	
	return 0;
}