Cod sursa(job #1318477)

Utilizator depevladVlad Dumitru-Popescu depevlad Data 15 ianuarie 2015 23:31:59
Problema Subsecventa de suma maxima Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include <cstdio>
#include <algorithm>

using namespace std;

#define MAX 6000001
#define INF 1<<30
#define inFile "ssm.in"
#define outFile "ssm.out"

int main() {
    freopen(inFile, "r", stdin);
    freopen(outFile, "w", stdout);
    
    int n, i, iStart, iEnd, iMin, elem, val, scurr, smin, sbest = -INF;
    
    scurr = iStart = iEnd = iMin = smin = 0;
    
    scanf("%d", &n);
    
    for(i = 1; i <= n; i++) {
        scanf("%d", &elem);
        scurr += elem;
        val = scurr - smin;
        if(smin >= scurr) {
            smin = scurr;
            iMin = i;
        }
        if(sbest < val) {
            sbest = val;
            iStart = iMin + 1;
            iEnd = i;
        }
    }
    printf("%d %d %d\n", sbest, iStart, iEnd);
    return 0;
}