Pagini recente » Cod sursa (job #2108948) | Cod sursa (job #250988) | Cod sursa (job #197653) | Cod sursa (job #596335) | Cod sursa (job #2544117)
#include <fstream>
#include <deque>
#define N 5000001
using namespace std;
ifstream f ( "deque.in" );
ofstream g ( "deque.out" );
deque < int > dq;
long long S;
int v[N];
int main()
{ int n, k, i;
f >> n >> k;
for ( i = 1; i <= n; i++ )
f >> v[i];
for ( i = 1; i <= n; i++ ){
while ( ! dq.empty ( ) && v[i] < v[dq.back ( )] )
dq.pop_back ( );
dq.push_back ( i );
while ( ! dq.empty ( ) && i - dq.front ( ) >= k )
dq.pop_front ( );
if ( i >= k )
S += v[dq.front ( )];
}
g << S;
return 0;
}