Pagini recente » Cod sursa (job #2073126) | Cod sursa (job #3161650) | Cod sursa (job #170774) | Cod sursa (job #3258648) | Cod sursa (job #2457134)
#include <iostream>
#include <deque>
#include <cstdio>
using namespace std;
int v[5000001];
int main()
{
freopen ( "deque.in", "r", stdin );
freopen ( "deque.out", "w", stdout );
int n, k;
int i;
long long s;
deque < int > d;
scanf ( "%d%d", &n, &k );
s = 0;
for ( i = 0; i < n; i ++ ){
scanf ( "%d", &v[i] );
while ( d.empty() == 0 && v[i] <= v[d.back()] )
d.pop_back();
d.push_back( i );
if ( i >= k - 1 )
s += v[d.front()];
if ( d.front() == i - k + 1 )
d.pop_front();
}
cout << s;
return 0;
}