Pagini recente » Cod sursa (job #2657268) | Cod sursa (job #1362191) | Cod sursa (job #1695219) | Cod sursa (job #2030975) | Cod sursa (job #2657224)
#include <iostream>
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
deque<pair<int, int> > D;
int n, k;
void citire()
{
fin>>n>>k;
int x, sumaMinima=0;
for(int i=0;i<n;i++)
{
if(!D.empty()&&i-D.front().second>=k)
D.pop_front();
fin>>x;
if(D.empty()||!D.empty()&&x>D.back().first)
D.push_back({x,i});
else
{
while(x<D.back().first&&!D.empty())
D.pop_back();
D.push_back({x,i});
}
if(i>=k-1)
sumaMinima+=D.front().first;
}
cout<<sumaMinima;
}
int main()
{
citire();
return 0;
}