Pagini recente » Cod sursa (job #1388835) | Cod sursa (job #7492) | Cod sursa (job #2168473) | Cod sursa (job #1356135) | Cod sursa (job #341580)
Cod sursa(job #341580)
#include <stdio.h>
#define N 5000005
int n,k,deq[N],x,v[N];
long long sum;
int inc,sf;
void capat(int i)
{
if (i-deq[inc]>=k)
inc++;
}
void actualizare(int i)
{
while (inc<=sf && v[i]<=v[deq[sf]])
sf--;
deq[++sf]=i;
}
void solve()
{
int i;
for (i=1; i<=k; i++)
{
scanf("%d",&v[i]);
actualizare(i);
}
sum=v[deq[inc]];
for (i=k+1; i<=n; i++)
{
scanf("%d",&v[i]);
actualizare(i);
capat(i);
sum+=v[deq[inc]];
}
}
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%d%d",&n,&k);
solve();
printf("%lld\n",sum);
return 0;
}