Pagini recente » Cod sursa (job #622986) | Cod sursa (job #2889313) | Cod sursa (job #1317574) | Arhiva de probleme | Cod sursa (job #1048820)
#include <iostream>
#include <fstream>
#include <deque>
#include <vector>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
deque <int> deq;
vector <int> v;
int main()
{
long k,i,n,s=0,x;
fin>>n>>k;
for (i=1;i<=n;i++)
{
fin>>x;
v.push_back(x);
while (!deq.empty() && v[deq.back()-1]>=v[i-1])
deq.pop_back();
deq.push_back(i);
if (deq.front()==i-k)
deq.pop_front();
if (i>=k)
s+=v[deq.front()-1];
}
fout<<s;
return 0;
}