Cod sursa(job #2907971)

Utilizator cyg_TheoPruteanu Theodor cyg_Theo Data 31 mai 2022 23:33:36
Problema Subsecventa de suma maxima Scor 85
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.57 kb
#include <cstdio>
#include <algorithm>
#include <cstring>

using namespace std;

typedef long long ll;
const int NMAX = 6e6+5;

int v[NMAX];

int main(){
	freopen("ssm.in", "r", stdin);
	freopen("ssm.out", "w", stdout);

	int n;
	scanf("%d", &n);

	scanf("%d", &v[0]);
	int bsum=v[0], first=1, last=0;
	int sum=v[0], start = 0;
	for(int i=1; i<n; ++i){
		scanf("%d", &v[i]);
		if(sum < 0){
			sum = v[i];
			start = i + 1;
		}else
			sum += v[i];

		if(bsum < sum){
			bsum = sum;
			first = start;
			last = i + 1;
		}
	}

	printf("%d %d %d\n", bsum, first, last);

	return 0;
}