Cod sursa(job #2080978)

Utilizator Cristian25Cristian Stanciu Cristian25 Data 3 decembrie 2017 18:35:29
Problema Subsecventa de suma maxima Scor 55
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include <iostream>
#include <fstream>

using namespace std;
ifstream in("ssm.in");
ofstream out("ssm.out");
int A[1000000],smax[1000000],N,sol,st,fin=1;
void Citire(int x[],int &m)
{
    ifstream in("ssm.in");
    in>>m;
    for(int i=1;i<=m;++i)
        in>>x[i];
}
int main()
{
    Citire(A,N);
    for(int i=1;i<=N;++i)
        smax[i]=max(smax[i-1]+A[i],A[i]);
    sol=smax[1];
    for(int i=2;i<=N;++i)
        if(smax[i]>sol)
        {
            sol=smax[i];
            fin=i;
        }
    out<<sol<<' ';
    st=fin;
    while(sol>0)
    {
        sol-=A[st];
        --st;
    }
    ++st;
    out<<st<<' '<<fin;
    return 0;
}