Pagini recente » Borderou de evaluare (job #1503200) | Borderou de evaluare (job #2150368) | Borderou de evaluare (job #2828158) | Borderou de evaluare (job #1574070) | Cod sursa (job #3182481)
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
deque <pair<int,int> > d;
long long int sum;
int a;
int n,k;
void deque1(int a, int poz);
void deque2(int a,int poz);
int main()
{
fin>>n>>k;
for(int i=1;i<=n;i++)
{
fin>>a;
if(i<k)
deque1(a,i);
else
if(i==k)
{
deque1(a,i);
sum+=d.front().first;
}
else
{
deque2(a,i);
}
}
fout<<sum;
return 0;
}
void deque1(int a,int poz)
{
while(d.size() && a<d.back().first)
{
d.pop_back();
}
d.push_back({a,poz});
}
void deque2(int a,int poz)
{
if(d.front().second<poz-k+1)
d.pop_front();
while(d.size() && a<d.back().first)
{
d.pop_back();
}
d.push_back({a,poz});
sum+=d.front().first;
}