Pagini recente » Cod sursa (job #2296045) | Cod sursa (job #3276329) | Cod sursa (job #2477008) | Cod sursa (job #1458025) | Cod sursa (job #982491)
Cod sursa(job #982491)
#include <fstream>
#include <deque>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int main()
{
int n,k,s=0;
deque<int> dq,dp;
f>>n>>k;
for(int i=1;i<=n;i++){
int x;
f>>x;
while(!dp.empty()&&dp.front()<=i-k){
dp.pop_front();
dq.pop_front();
}
while(!dq.empty()&&x<=dq.back()){
dq.pop_back();
dp.pop_back();
}
dq.push_back(x);
dp.push_back(i);
if(i>=k)
s+=dq.front();
}
g<<s;
return 0;
}