Pagini recente » Cod sursa (job #918534) | Cod sursa (job #536734) | Cod sursa (job #3213622) | Cod sursa (job #2216060) | Cod sursa (job #2541676)
#include <fstream>
#include <deque>
#include <vector>
using namespace std;
ifstream cin("deque.in");
ofstream cout("deque.out");
deque<int>coada;
vector<int>a;
int n,k,sum = 0;
void citire()
{
cin>>n>>k;
a.push_back(0);
for(int i=1;i<=n;i++)
{
int x;
cin>>x;
a.push_back(x);
}
}
int main()
{
citire();
for(int i=1;i<=n;i++)
{
while(!coada.empty() && a[i] <= a[coada.back()])
coada.pop_back();
coada.push_back(i);
if(coada.front() == i-k)
coada.pop_front();
if(i >= k)
sum += a[coada.front()];
}
cout<<sum<<'\n';
}