Pagini recente » Cod sursa (job #2591196) | Cod sursa (job #42675) | Cod sursa (job #852570) | Cod sursa (job #785835) | Cod sursa (job #553028)
Cod sursa(job #553028)
#include <fstream.h>
ifstream f("deque.in");
ofstream g("deque.out");
int n,k,Deque[5000001],A[5000001];
int main()
{
int i,Front=1,Back=0;
long long S=0;
f>>n>>k;
for(i=1;i<=n;i++)
f>>A[i];
for(i=1;i<=n;i++)
{
while(Front<=Back && A[i]<=A[Deque[Back]]) Back--;
Deque[++Back]=i;
if(Deque[Front]==i-k) Front++;
if(i>=k) S+=A[Deque[Front]];
}
g<<S<<'\n';
f.close();
g.close();
return 0;
}