Pagini recente » Cod sursa (job #2938774) | Cod sursa (job #2861237) | Cod sursa (job #2600111) | Cod sursa (job #3126116) | Cod sursa (job #3128123)
#include <iostream>
#include <deque>
#include <fstream>
using namespace std;
int v[5000001], dq[5000001];
long long sum;
//deque<int> dq;
ifstream in("deque.in");
ofstream out("deque.out");
int main() {
int n, k, i;
int Front=1, Back=0;
in >> n >> k;
for (i = 1; i <= n; i++)
in >> v[i];
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)
sum += v[ dq[Front]];
}
out << sum << endl;
in.close();
out.close();
return 0;
}