Cod sursa(job #2085125)

Utilizator Mihai145Oprea Mihai Adrian Mihai145 Data 9 decembrie 2017 18:46:58
Problema Subsecventa de suma maxima Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.74 kb
#include <bits/stdc++.h>
#define NMAX 6000000
using namespace std;
ifstream fin("ssm.in");
ofstream fout("ssm.out");
int n, v[NMAX+2], s=INT_MIN, smax=INT_MIN, stsv, drsv, st, maxel=INT_MIN, pozmaxel;
int main()
{
    int i;
    fin>>n;
    for(i=1; i<=n; i++)
    {
        fin>>v[i];
        if(v[i]>maxel)
        {
            maxel=v[i];
            pozmaxel=i;
        }
    }
    for(i=1; i<=n; i++)
    {
        if(s<0)
            s=v[i], st=i;
        else s+=v[i];
        if(s>smax)
        {
            smax=s;
            stsv=st;
            drsv=i;
        }
    }
    if(smax>maxel)
    fout<<smax<<' '<<stsv<<' '<<drsv<<'\n';
    else fout<<maxel<<' '<<pozmaxel<<' '<<pozmaxel<<'\n';
    return 0;
}