Pagini recente » Cod sursa (job #1774409) | Cod sursa (job #1872749) | Cod sursa (job #1924581) | Cod sursa (job #18360) | Cod sursa (job #1008117)
#include <iostream>
using namespace std;
#define Nmax 5000005
#include<fstream>
ifstream eu("deque.in");
ofstream tu("deque.out");
int K,N,A[Nmax],Deque[Nmax],Front,Back;
long long S;
void read()
{
eu>>N>>K;
for(int i=1;i<=N;i++)
eu>>A[i];
}
int main()
{
read();
Front=1;
Back=0;
for(int 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]];
}
tu<<S;
return 0;
}