Pagini recente » Cod sursa (job #1321426) | Cod sursa (job #1225973) | Cod sursa (job #921220) | Cod sursa (job #544236) | Cod sursa (job #1717772)
#include <fstream>
#include <deque>
using namespace std;
struct punct
{
int val;
int poz;
};
int main()
{
fstream in("deque.in");
ofstream out("deque.out");
deque<punct> coada;
long long sum = 0;
int n, k; in >> n >> k;
for (int i = 1; i <= n; i++)
{
int x; in >> x;
punct p; p.poz = i; p.val = x;
while (!coada.empty() && p.val <= coada.back().val) coada.pop_back();
coada.push_back(p);
if (coada.front().poz == i - k) coada.pop_front();
if (i >= k)
sum += coada.front().val;
}
out << sum << endl;
return 0;
}