Pagini recente » Cod sursa (job #1116684) | Cod sursa (job #3136595) | Cod sursa (job #2807820) | Cod sursa (job #1281450) | Cod sursa (job #2451482)
#include <fstream>
#include <iostream>
#define nmax 5000001
using namespace std;
ifstream in("deque.in");
ofstream out("deque.out");
int N, K, a[nmax], deque[nmax];
int main(){
in >> N >> K;
for(int i = 1; i<=N; i++)
in >> a[i];
int Front = 1, Back = 0;
long long sum = 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) sum+= a[deque[Front]];
}
out << sum;
return 0;
}