Cod sursa(job #1046722)

Utilizator BuseSorinFMI Buse Sorin-Marian BuseSorin Data 3 decembrie 2013 13:37:12
Problema Deque Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.55 kb
#include<fstream>
#include<deque>
#include<vector>

using namespace std;

int main(){
	ifstream f("deque.in");
	ofstream cout("deque.out");
	int n,k;
	f>>n>>k;
	deque<int> d;
	long long s=0;
	vector<long long> vector;
	for(int i=0;i<n;i++){
		long long x=0;
		f>>x;
		vector.push_back(x);
	}
	k--;
	for(int i=0;i<n;i++){
		while(d.size()>0 && vector[i]<=vector[d.back()]){
			d.pop_back();
		}
		d.push_back(i);
		if(d.front()==i-k-1){
			d.pop_front();
		}
		if(i>=k){
			s+=vector[d.front()];
		}
		
	}
	cout<<s;
	return 0;
}