Pagini recente » Cod sursa (job #2013904) | Cod sursa (job #1013783) | Cod sursa (job #1916257) | Cod sursa (job #556959) | Cod sursa (job #1076809)
#include <fstream>
using namespace std;
ifstream f ("deque.in");
ofstream g("deque.out");
int n,k,front,back,i;
int DQ[5000005],v[5000005];
long long suma;
int main ()
{
f >> n >> k;
for (i = 1; i <= n; i++)
f >> v[i];
front = 1;
back = 0;
for (i = 1; i <= n; i++)
{
while (front <= back && v[i] <= v[DQ[back]]) back--;
DQ[++back] = i;
if (DQ[front] == i-k) front++;
if (i >= k) suma += v[DQ[front]];
}
g << suma;
f.close();
g.close();
return 0;
}