Cod sursa(job #2574191)
Utilizator | Cretoiu Patricia PatriciaCretoiu | Data | 5 martie 2020 20:53:12 |
---|---|---|---|
Problema | Deque | Scor | 25 |
Compilator | cpp-64 | Status | done |
Runda | r3capitusulare | Marime | 0.63 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream in("deque.in");
ofstream out("deque.out");
int n, k, i, x;
deque < pair <int, int> > dq;
int main()
{
in >> n >> k;
int ans = 0;
for(i = 1; i <= n; i++)
{
in >> x;
if(!dq.empty())
while(x <= dq.back().first)
{
dq.pop_back();
if(dq.empty()) break;
}
dq.push_back({x,i});
if(i >= k)
ans += dq.front().first;
if(dq.front().second + k - 1 == i)
dq.pop_front();
}
out << ans;
return 0;
}