Pagini recente » Cod sursa (job #1862381) | Cod sursa (job #423572) | Cod sursa (job #323446) | Cod sursa (job #2878899) | Cod sursa (job #632062)
Cod sursa(job #632062)
#include<stdio.h>
using namespace std;
int A[5000000],Coada[5000000],n,k;
long long suma;
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
int i;
scanf("%d%d",&n,&k);
for(i=1;i<=n;i++)
scanf("%d",&A[i]);
int cap=1,spate=0;
for(i=1;i<=n;i++)
{
while(cap<=spate&&A[i]<=A[Coada[spate]])
spate--;
spate++;
Coada[spate]=i;
if(Coada[cap]==i-k)
cap++;
if(i>=k)
suma+=A[Coada[cap]];
}
printf("%lld",suma);
return 0;
}