Pagini recente » Diferente pentru home intre reviziile 359 si 358 | Istoria paginii utilizator/suteuionut | Diferente pentru home intre reviziile 186 si 185 | Cod sursa (job #658051) | Cod sursa (job #264848)
Cod sursa(job #264848)
#include <stdio.h>
int e[50001];
int f[50001];
int main()
{
int n,k,i;
int st,dr,rezultat,start,rez,ver;
freopen("secv2.in","r",stdin);
freopen("secv2.out","w",stdout);
scanf("%d %d",&n,&k);
for(i=1;i<=n;i++)
{
scanf("%d",&e[i]);
f[i]=f[i-1]+e[i];
}
st=1;
dr=k;
start=1;
ver=f[k];
rez=f[k];
for(i=k+1;i<=n+1;i++)
{
ver=ver+e[i];
if(ver<f[i]-f[i-k])
{
ver=f[i]-f[i-k];
start=i-k+1;
}
if(rez<ver)
{
rez=ver;
dr=i;
st=start;
}
}
printf("%d %d %d",st,dr,rez);
return 0;
}