Pagini recente » Cod sursa (job #1722485) | Cod sursa (job #1766811) | Cod sursa (job #1107329) | Cod sursa (job #933577) | Cod sursa (job #1871690)
#include <fstream>
#define maxn 5000010
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int n, k, deq[maxn], v[maxn];
int Front = 1, Back; // deque vid
long long Sum;
int main(){
f >> n >> k;
for(int i=1; i<=n; ++i) f >> v[i];
for(int i=1; i<=n; ++i){
while(Front <= Back && v[i] <= v[deq[Back]]) --Back;
deq[++Back] = i;
if(deq[Front] == i-k) Front++;
if(i >= k) Sum += v[deq[Front]];
}
g << Sum << '\n';
}