Cod sursa(job #1596782)

Utilizator dimavascan94VascanDumitru dimavascan94 Data 11 februarie 2016 13:31:28
Problema Subsecventa de suma maxima Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.65 kb
#include <iostream>
using namespace std;

int start, finish, sum = INT_MIN, aux, N, numbers[6000000];

int main()
{
	freopen("ssm.in", "r", stdin);
	freopen("ssm.out", "w", stdout);
	cin >> N;
	for (int i = 0; i < N; i++)
	{
		scanf("%d", &numbers[i]);
	}

	for (int i = 0; i < N; ++i)
	{
		for (int j = N - 1; j >= i; --j)
		{
			aux = 0;
			for (int z = i; z <= j; ++z)
			{
				aux += numbers[z];
			}
			if (aux>sum)
			{
				sum = aux;
				start = i;
				finish = j;
			}
			if (aux == sum && ((j - i) < (finish - start)))
			{
				start = i;
				finish = j;
			}
		}
	}
	printf("%d %d %d", sum, start + 1, finish + 1);
}