Pagini recente » Cod sursa (job #2489264) | Cod sursa (job #1337107) | Cod sursa (job #2752540) | Cod sursa (job #1812235) | Cod sursa (job #1274562)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
const int NMax = 5000010;
int v[NMax],dq[NMax];
int main()
{
int N,K,fata,spate;
long long int sum = 0;
f >> N >> K;
for(int i = 1; i <= N; i++)
f >> v[i];
fata = 1;
spate = 0;
for(int i = 1; i <= N; i++){
while(fata <= spate && v[i] <= v[dq[spate]])
spate--;
dq[++spate] = i;
if(dq[fata] == i - K)
fata++;
if(i >= K)
sum += v[dq[fata]];
}
g << sum;
return 0;
}