Pagini recente » Cod sursa (job #1527448) | Cod sursa (job #306552) | Cod sursa (job #223483) | Cod sursa (job #1065436) | Cod sursa (job #1521466)
#include <iostream>
#include <fstream>
#define MAX_N 500001
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;
}