Pagini recente » Cod sursa (job #112107) | Cod sursa (job #1591223) | Cod sursa (job #2205392) | Cod sursa (job #2727039) | Cod sursa (job #2888730)
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
deque <long long> minim;
long long v[5000001];
int main()
{
long long n, k;
long long rez = 0;
fin >> n >> k;
long long i, j;
for (i = 1; i <= n; ++i)
{
fin >> v[i];
while (!minim.empty() && v[minim.back()] >= v[i])
minim.pop_back();
minim.push_back(i);
if (!minim.empty() && minim.front() == i - k)
minim.pop_front();
if (i >= k)
{
long long x = v[minim.front()];
rez += x;
}
}
fout << rez;
return 0;
}