Pagini recente » Borderou de evaluare (job #373444) | Borderou de evaluare (job #1587808) | Borderou de evaluare (job #1974731) | Borderou de evaluare (job #1640921) | Cod sursa (job #1114042)
#include <fstream>
#include <deque>
using namespace std;
int N,k,a[5000005];
long long sum;
deque<int> D;
int main()
{
ifstream f("deque.in");
f>>N>>k;
for(register int i=1 ; i<=N ; ++i )
f>>a[i];
f.close();
for(register int i=1;i<=N;++i){
while( !D.empty() && a[ D.back() ] >= a[i] ) D.pop_back();
D.push_back(i);
if( D.front() == i-k ) D.pop_front();
if(i>=k) sum+=a[D.front()];
}
ofstream g("deque.out");
g<<sum;
g.close();
return 0;
}