Pagini recente » Cod sursa (job #1236575) | Cod sursa (job #1389324) | Cod sursa (job #1397058) | Istoria paginii runda/simulareoji3/clasament | Cod sursa (job #2304555)
#include <fstream>
using namespace std;
ifstream fin( "deque.in" );
ofstream fout( "deque.out" );
const int N = 5000000;
int dq[ N ];
long long v[ N ];
int main()
{
int n = 0, k = 0, st = 0, dr = -1;
long long s = 0;
fin >> n >> k;
for( int i = 0; i < n; ++i )
{
fin >> v[ i ];
}
for( int i = 0; i < n; ++i )
{
if( st <= dr && dq[ st ] == i - k )
++st;
while( st <= dr && v[ i ] <= v[ dq[ dr ] ] )
--dr;
dq[ ++dr ] = i;
if( i >= k - 1 )
s += v[ dq[ st ] ];
}
fout << s;
return 0;
}