Pagini recente » Diferente pentru sandbox intre reviziile 79 si 78 | Cod sursa (job #1522898) | Cod sursa (job #1522896) | Cod sursa (job #1505386) | Cod sursa (job #3218636)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int i,n,k,p,u,v[5000005],d[5000005];
long long s;
int main()
{
fin>>n>>k;
for(i=1;i<=n;i++)fin>>v[i];
d[1]=1;
p=u=1;
for(i=2;i<=n;i++)
{
while(p<=u&&v[i]<=v[d[u]])u--;
u++; d[u]=i;
if(i-d[p]==k)p++;
if(i>=k)s+=v[d[p]];
}
fout<<s;
return 0;
}