Pagini recente » Cod sursa (job #2204789) | Istoria paginii runda/simulare9_31_10_1 | Cod sursa (job #1031745) | Cod sursa (job #1612914) | Cod sursa (job #2044255)
#include <iostream>
#include <deque>
#include <queue>
#include <fstream>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int v[5000001];
int main()
{
int i,s=0,n,k;
fin>>n>>k;
for(i=1; i<=n; ++i)
{
fin>>v[i];
}
deque <int> d;
for(i=1; i<=n; ++i)
{
while(!d.empty() && v[d.back()]>=v[i])
d.pop_back();
d.push_back(i);
if(i-k==d.front())
d.pop_front();
if(i>=k)
s+=v[d.front()];
}
fout<<s;
return 0;
}