Pagini recente » Cod sursa (job #237039) | Cod sursa (job #1034977) | Cod sursa (job #2855147) | Cod sursa (job #1592028) | Cod sursa (job #1521467)
#include <iostream>
#include <fstream>
#define MAX_N 5000001
using namespace std;
int A[MAX_N],D[MAX_N];
int n,k,Front,Back;
long long S;
int main()
{
ifstream f("deque.in");
f>>n>>k;
Front=1;
Back=0;
for(int i=1;i<=n;i++)
{
f>>A[i];
while(Front<=Back && A[i]<=A[D[Back]])Back--;
D[++Back]=i;
if(D[Front]==i-k) Front++;
if(i>=k)S+=A[D[Front]];
}
f.close();
ofstream g("deque.out");
g<<S;
g.close();
return 0;
}