Pagini recente » Cod sursa (job #2659156) | Cod sursa (job #3139606) | Cod sursa (job #190251) | Cod sursa (job #674827) | Cod sursa (job #2371688)
#include <iostream>
#include <fstream>
#include <algorithm>
#include <vector>
#include <utility>
#include <cmath>
#include <string>
#include <cstring>
#include <set>
#include <queue>
#include <map>
#include <deque>
#define ll long long
#define lsb(x) (x & -x)
using namespace std;
ifstream in("deque.in");
ofstream out("deque.out");
int main() {
int n, k;
in >> n >> k;
vector<int> v(n + 1, 0);
vector<int> d(n + 1, 0);
int le = 1, ri = 0;
ll ans = 0;
for(int i = 1; i <= n; i ++) {
in >> v[i];
while(le <= ri && v[d[ri]] > v[i])
ri --;
d[++ri] = i;
if(i >= k)
ans += 1LL * v[d[le]];
if(i - d[le] == k - 1)
le ++;
}
out << ans;
return 0;
}