Pagini recente » Cod sursa (job #783506) | Cod sursa (job #1900786) | Arhiva de probleme | Arhiva de probleme | Cod sursa (job #2870946)
#include <bits/stdc++.h>
#pragma GCC optimize ("Ofast")
using namespace std;
ifstream fin ("deque.in");
ofstream fout ("deque.out");
const int MAX_N = 5000005;
deque <int> minn;
int n, k, v[MAX_N];
long long sol;
int main (){
ios_base::sync_with_stdio(false);
fin.tie(nullptr);
fout.tie(nullptr);
fin>>n>>k;
for(int i=1; i<=n; i++){
fin>>v[i];
while(!minn.empty() && v[i] <= v[minn.back()])
minn.pop_back();
minn.push_back(i);
if(i >= k){
sol += v[minn.front()];
if(minn.front() == i-k+1)
minn.pop_front();
}
}
fout<<sol;
return 0;
}