Cod sursa(job #1538903)

Utilizator theep0Cruceru Radu theep0 Data 29 noiembrie 2015 23:14:05
Problema Subsecventa de suma maxima Scor 100
Compilator c Status done
Runda Arhiva educationala Marime 0.63 kb
#include <stdio.h>
#include <stdlib.h>

#define MN 6000002

int S[MN];

int main() {
    int i, minj, N, best, idx, besti, min;
    freopen("ssm.in", "r", stdin);
    freopen("ssm.out", "w", stdout);
    scanf("%d", &N);
    for(i = 1; i <= N; i++) {
        scanf("%d", S + i);
        S[i] += S[i-1];
    }
    minj = 1;
    min = 0;
    best = -1*(1<<29);
    besti = 1;
    for(i = 1; i <= N; i++) {
        if (best < S[i] - min) {
            best = S[i] - min, besti = i, minj = idx + 1;
        }
        if (min > S[i]) {
            min = S[i], idx = i;
        }
    }
    printf("%d %d %d\n", best, minj, besti);
    return 0;
}