Pagini recente » Cod sursa (job #1341010) | Istoria paginii runda/ice_cream_van | Monitorul de evaluare | Cod sursa (job #2195983) | Cod sursa (job #2936675)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
long long v[5000005],coada[5000005];
long long s;
int main()
{
int n,k,i,inc,sf;
v[0]=-10000001;
sf=0;
inc=0;
fin>>n>>k;
for(i=1; i<=n; i++)
{
fin>>v[i];
if(i<k)
{
while (inc<=sf && v[i]<v[coada[sf]])
sf--;
coada[++sf]=i;
}
else
{
if(i-k>=coada[inc])
inc++;
while (inc<=sf && v[i]<v[coada[sf]])
sf--;
coada[++sf]=i;
s=s+v[coada[inc]];
}
}
fout<<s;
return 0;
}