Pagini recente » Cod sursa (job #2361011) | Cod sursa (job #564272) | Cod sursa (job #2427671) | Cod sursa (job #2094085) | Cod sursa (job #982494)
Cod sursa(job #982494)
#include <fstream>
#include <deque>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int main()
{
long long n,k,s=0;
deque<long long> dq,dp;
f>>n>>k;
for(long long i=1;i<=n;i++){
long long 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;
}