Pagini recente » Cod sursa (job #3215365) | Cod sursa (job #2708905) | Cod sursa (job #882301) | Cod sursa (job #2731410) | Cod sursa (job #2889519)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int v[5000010]={}, dq[5000010]={};
int main()
{
int n, k, i, front=1, back=0;
long long suma=0;
fin>>n;
fin>>k;
for(i=1;i<=n;i++)
fin>>v[i];
for(i=1;i<=n;i++)
{
while(front <= back && v[i] <= v[dq[back]])
back--;
back++;
dq[back] = i;
if(dq[front] ==i-k)
front++;
if(i >= k)
suma += v[dq[front]];
}
fout<<suma;
fin.close();
fout.close();
return 0;
}