Pagini recente » Cod sursa (job #260233) | Cod sursa (job #1045777) | Cod sursa (job #2608324) | Cod sursa (job #893935) | Cod sursa (job #2888669)
#include <iostream>
#include <deque>
#include <fstream>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int main()
{ long long int v[5000004], s = 0;
unsigned int i, n, k;
deque <long long int> mydeque(n+5);
f>>n>>k;
for(i = 1; i <= n; i++)
f>>v[i];
for(i = 1; i <= n; i++){
while(!mydeque.empty() && v[i] < v[mydeque.back()])
mydeque.pop_back();
mydeque.push_back(i);
if(i >= k) {
s += v[mydeque.front()];
// cout<<v[mydeque.front()]<<" ";
if(mydeque.front() == i - k + 1)
mydeque.pop_front();
}
}
g << s;
f.close();
g.close();
return 0;
}