Pagini recente » Cod sursa (job #2789462) | Cod sursa (job #1932606) | Cod sursa (job #1634199) | Cod sursa (job #1429781) | Cod sursa (job #2371659)
#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);
deque<int> d;
ll ans = 0;
for(int i = 1; i <= n; i ++) {
in >> v[i];
while(d.size() && v[d.front()] > v[i])
d.pop_front();
d.push_back(i);
if(i >= k)
ans += 1LL * v[d.front()];
if(i - d.front() == k - 1)
d.pop_front();
}
out << ans;
return 0;
}