Pagini recente » Cod sursa (job #2954697) | Cod sursa (job #256190) | Cod sursa (job #2873342) | Cod sursa (job #930598) | Cod sursa (job #1729510)
#include <deque>
#include <fstream>
#define ll long long
#define f first
#define s second
using namespace std;
deque<pair<ll,ll> > d;
ll n,c,k,ans;
int main()
{
ifstream fin("deque.in");
ofstream fout("deque.out");
fin>>n>>k;
for(int i=0;i<n;i++) {
if(!d.empty()&&i>=k)
ans+=d.front().f;
if(!d.empty()&&d.front().s<=i-k)
d.pop_front();
fin>>c;
while(!d.empty()&&d.back().f>c)
d.pop_back();
d.push_back({c,i});
}
ans+=d.front().f;
fout<<ans;
return 0;
}