Cod sursa(job #2469862)

Utilizator kywyPApescu tiGEriu kywy Data 8 octombrie 2019 09:33:48
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.54 kb
#include <cstdio>
#include <deque>
using namespace std;

FILE* in=fopen("deque.in", "r");
FILE* out=fopen("deque.out", "w");
deque<pair<int, int> > d; 

int main()
{
	int n, k;
	
	fscanf(in, "%d%d", &n, &k);
	
	int x;
	fscanf(in, "%d", &x);
	d.push_back(make_pair(x, 1));
	
	long long sum=0;
	for(int i=2; i<=n; ++i)
	{
		fscanf(in, "%d", &x);
		while(!d.empty()&&d.back().first>=x) d.pop_back();
		d.push_back(make_pair(x, i));
		while(!d.empty()&&d.front().second+k-1<i) d.pop_front();
		if(i>=k) sum+=d.front().first;
	}
	fprintf(out, "%lld", sum);
}