Cod sursa(job #2080968)

Utilizator Cristian25Cristian Stanciu Cristian25 Data 3 decembrie 2017 18:26:40
Problema Subsecventa de suma maxima Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.69 kb
#include <iostream>
#include <fstream>

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