Cod sursa(job #1809749)

Utilizator caprariuapCaprariu Alin-Paul caprariuap Data 19 noiembrie 2016 11:13:06
Problema Secventa 2 Scor 90
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.69 kb
#include <cstdio>
#include <vector>
#define nmax 50010

using namespace std;

FILE *fin=fopen("secv2.in","r");
FILE *fout=fopen("secv2.out","w");

long long n,k,s,minim[nmax],maxim,sf,st,inc[nmax],i,a;

int main()
{
   fscanf(fin,"%lld%lld",&n,&k);
   for (i=1; i<=n; i++)
   {
      fscanf(fin,"%lld",&a);
      s+=a;
      minim[i]=minim[i-1];
      inc[i]=inc[i-1];
      if (s-minim[i-k]>maxim)
      {
         maxim=s-minim[i-k];
         sf=i;
         st=inc[i-k]+1;
      }
      if (s<minim[i])
      {
         inc[i]=i;
         minim[i]=s;
      }
   }
   if (n!=1)
   fprintf(fout,"%lld %lld %lld\n",st,sf,maxim);
   else
      fprintf(fout,"1 1 %lld\n",a);
}