Pagini recente » Cod sursa (job #1323738) | Cod sursa (job #1297120) | Cod sursa (job #1453496) | Cod sursa (job #1019136) | Cod sursa (job #1046049)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f ("deque.in");
ofstream g ("deque.out");
#define MaxN 5000010
int main()
{
int n,k,i;
int a[MaxN], Dque[MaxN];
int Front, Back;
long long sum=0;
f>>n>>k;
for(i=0;i<n;i++)
f>>a[i];
Front=1;Back=1;
Dque[Back]=0;
for (i=1;i<n;i++)
{
while (Front<=Back && a[i]<a[Dque[Back]])
Back--;
Dque[++Back]=a[i];
if (Dque[Front]==i-k)
Front++;
if(i>=k)
sum+=a[Dque[Front]];
}
g<<sum;
f.close();
g.close();
return 0;
}