Cod sursa(job #2907983)

Utilizator cyg_TheoPruteanu Theodor cyg_Theo Data 31 mai 2022 23:48:01
Problema Subsecventa de suma maxima Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.71 kb
#include <cstdio>
#include <cstring>
#include <cstdlib>

using namespace std;

const int NMAX = 6e6+5;

int v[NMAX];
char s[NMAX*10];

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

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

	fgets(s, NMAX*10, stdin);

	char *p = strtok(s, " ");
	for(int i=0; i<n; ++i){
		v[i] = atoi(p);
		p = strtok(NULL, " ");
	}

	int bsum=v[0], first=0, last=0, sum=v[0], start=0;
	for(int i=1; i<n; ++i){
		start = (sum < 0)*i + (sum >= 0)*start;
		sum = v[i] + (sum >= 0)*sum;

		first = (bsum < sum)*start + (bsum >= sum)*first;
		last = (bsum < sum)*i + (bsum >= sum)*last;
		bsum = (bsum < sum)*sum + (bsum >= sum)*bsum;
	}

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

	return 0;
}