Pagini recente » Cod sursa (job #1571707) | Cod sursa (job #2206987) | Cod sursa (job #2150404) | Cod sursa (job #2206965) | Cod sursa (job #3330467)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
deque< pair<int, int> > d;
int n, k, a[5000005], s;
int main()
{
int i, j;
fin >> n >> k;
for(i = 1; i <= n; i++)
fin >> a[i];
for(i = 1; i <= k; i++)
{
while(!d.empty() && a[i] < d.back().first)
d.pop_back();
d.push_back({a[i], i});
}
s += d.front().first;
for(i = k + 1; i <= n; i++)
{
if(i - d.front().second >= k)
d.pop_front();
while(!d.empty() && a[i] < d.back().first)
d.pop_back();
d.push_back({a[i], i});
s += d.front().first;
}
fout << s << "\n";
return 0;
}