Pagini recente » Cod sursa (job #578462) | Cod sursa (job #721105) | Cod sursa (job #1232716) | Cod sursa (job #2529034) | Cod sursa (job #1419452)
#include <cstdio>
#include <deque>
using namespace std;
const int mx = 5000005 ;
deque <int> d;
int v[mx],n,k ;
long long rez = 0 ;
int main()
{
freopen( "deque.in" , "r" , stdin ) ;
freopen( "deque.out" , "w" , stdout ) ;
scanf( "%d %d" , &n , &k ) ;
for ( int i = 1 ; i <= n ; i ++ )
{
scanf( "%d" , &v[i] ) ;
while ( not d.empty() && v[d.back()] > v[i] )
d.pop_back() ;
d.push_back(i) ;
if ( not d.empty() && d.front() == i - k )
d.pop_front() ;
if ( i >= k )
rez += 1LL * v[d.front()] ;
}
printf( "%lld\n" , rez ) ;
return 0;
}