Pagini recente » Cod sursa (job #443560) | Cod sursa (job #1362413) | Monitorul de evaluare | Cod sursa (job #1784124) | Cod sursa (job #3310203)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int n, k;
deque<pair<int, int>> dq;
int main() {
fin >> n >> k;
int sum = 0;
for(int i = 1; i <= n; i++)
{
int x, min;
fin >> x;
while(!dq.empty() && i - dq.front().second + 1 > k)
{
dq.pop_front();
}
while(!dq.empty() && dq.back().first >= x)
{
dq.pop_back();
}
if(dq.empty())
{
min = x;
}
else{
min = dq.front().first;
}
if(i >= k)
{
sum += min;
}
dq.push_back({x, i});
}
fout << sum;
return 0;
}