Cod sursa(job #1134085)

Utilizator MariusMocanuMocanu Marius-Alexandru @ASECIB MariusMocanu Data 5 martie 2014 23:05:06
Problema Subsecventa de suma maxima Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include <iostream>
#include<fstream>
#include <limits.h>
using namespace std;

int max(int a, int b)
{
	return a > b ? a : b;
}
int main()
{
	long n, v, startindex = 1, endindex = 1, partialsum = 0, partialsumLast = 0, bestsum = INT_MIN;
	ifstream fin("ssm.in");
	ofstream fout("ssm.out");
	fin >> n;
	for (int i = 1; i <= n; i++)
	{
		fin >> v;
		partialsumLast = partialsum;
		partialsum = max(partialsumLast + v, v);
		if (partialsumLast<0 && partialsum>partialsumLast)
			startindex = i;
		if (bestsum < partialsum)
		{
			bestsum = partialsum;
			endindex = i;
		}
	}
	cout << bestsum << " " << startindex << " " << endindex;
	return 0;
}