Pagini recente » Cod sursa (job #3233952) | Cod sursa (job #1524280) | Cod sursa (job #1814949) | Cod sursa (job #2961649) | Cod sursa (job #1797400)
#include <fstream>
using namespace std;
unsigned int N, K;
int a[5000001];
int Deque[5000001];
unsigned int i, Front, Back;
long long int sol;
int main ()
{
ifstream fin ("deque.in");
fin >> N >> K;
for (i=1; i<=N; i++)
fin >> a[i];
fin.close();
Front = 1;
for (i=1; i<=N; i++)
{
while (Front <= Back && a[i] <= a[Deque[Back]])
Back--;
Deque[++Back] = i;
if (Deque[Front] == i-K)
Front++;
if (i >= K)
sol += a[Deque[Front]];
}
ofstream fout ("deque.out");
fout << sol;
fout.close();
return 0;
}