Pagini recente » Cod sursa (job #1947775) | Cod sursa (job #1440265) | Cod sursa (job #3212009) | Cod sursa (job #3210818) | Cod sursa (job #2777830)
#include <fstream>
#include <deque>
using namespace std;
ifstream fin ("deque.in");
ofstream fout ("deque.out");
struct nr
{
int val, poz;
};
deque<nr> deq;
int n, k;
long long s;
nr x;
int main()
{
fin>>n>>k;
for(int i=1; i<=n; i++)
{
fin>>x.val;
x.poz=i;
while(!deq.empty() && deq.front().poz<i-k+1) deq.pop_front();
while(!deq.empty() && deq.back().val>x.val) deq.pop_back();
deq.push_back(x);
if(i>=k) s+=deq.front().val;
}
fout<<s;
return 0;
}