Pagini recente » Diferente pentru problema/padurari intre reviziile 8 si 7 | Borderou de evaluare (job #3046585) | Cod sursa (job #1705838) | Cod sursa (job #2690864) | Cod sursa (job #2695731)
#include<cstdio>
#define N 5000001
int v[N],d[N],p=1,u,i,n,k;
long long s;
int main()
{
freopen("deque.in","r",stdin),freopen("deque.out","w",stdout),scanf("%d%d",&n,&k);
for(i=1;i<=n;i++)
scanf("%d",v+i);
for(i=1;i<k;i++)
{
while(p<=u&&v[i]<=v[d[u]])
u--;
d[++u]=i;
}
for(i=k;i<=n;i++)
{
while(p<=u&&v[i]<=v[d[u]])
u--;
d[++u]=i;
if(d[p]==i-k)
p++;
s+=v[d[p]];
}
printf("%lld",s);
}