Pagini recente » Cod sursa (job #555497) | Cod sursa (job #2271911) | Cod sursa (job #3280422) | Cod sursa (job #3178457) | Cod sursa (job #2714072)
#include <fstream>
using namespace std;
const int N = 5000000;
ifstream cin("deque.in");
ofstream cout("deque.out");
int v[N], dq[N];
int main()
{
int n, k, st, dr;
cin >> n >> k;
long long s = 0;
st = 0;
dr = -1;
for ( int i = 0; i < n; i++)
{
cin >> v[i];
if ( st <= dr && dq[st] == i - k)//eliminare din stanga
{
st++;
}
while ( st <= dr && v[i] <= v[dq[dr]])//eliminare din dreapta
{
dr--;
}
dq[++dr] = i;
if ( i >= k - 1)
{
s += v[dq[st]];
}
}
cout << s;
return 0;
}