Pagini recente » Istoria paginii utilizator/sormur | Istoria paginii onis-2014/clasament-final | Monitorul de evaluare | Monitorul de evaluare | Cod sursa (job #1900524)
#include <fstream>
#include <deque>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
long long n,k,i,j,minim;
struct el
{
long long v,cnt;
};
el p;
deque <el> q;
int main()
{
f>>n>>k;
f>>p.v;
q.push_back(p);
for(i=1;i<k;i++)
{
f>>p.v;
p.cnt=i;
j=q.size()-1;
while(j>=0&&q[j].v>p.v) q.pop_back(),j--;
q.push_back(p);
}
minim+=q[0].v;
for(i=k;i<n;i++)
{
f>>p.v;
p.cnt=i;
j=q.size()-1;
while(j>=0&&q[j].v>p.v) q.pop_back(),j--;
q.push_back(p);
if(i-q[0].cnt>k-1) q.pop_front();
minim+=q[0].v;
}
g<<minim;
return 0;
}