Cod sursa(job #1416079)

Utilizator tziplea_stefanTiplea Stefan tziplea_stefan Data 7 aprilie 2015 11:50:56
Problema Secventa 2 Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.89 kb
#include <fstream>
#define NM 50005

using namespace std;

ifstream fin("secv2.in");
ofstream fout("secv2.out");

int n, k, i, v[NM], dp[NM];
int sum, maxsum, be, en, poz;

void read()
{
    fin >> n >> k;
    for (i=1; i<=n; i++)
    {
        fin >> v[i];
        if (i<=k)
          sum+=v[i];
    }
}

void subsecvmax()
{
    dp[k]=sum;
    maxsum=sum;
    be=1;
    en=k;
    for (i=k+1; i<=n; i++)
    {
        if (dp[i-1]>sum)
          dp[i]=dp[i-1]+v[i];
        else
        {
            dp[i]=sum+v[i];
            poz=i-k;
        }
        if (dp[i]>maxsum)
        {
            be=poz;
            en=i;
            maxsum=dp[i];
        }
        sum-=v[i-k];
        sum+=v[i];
    }
    fout << be << " " << en << " " << maxsum << '\n';
}

int main()
{
    read();
    subsecvmax();
    fin.close();
    fout.close();
    return 0;
}