Cod sursa(job #3127495)

Utilizator willOcanaru Mihai will Data 7 mai 2023 15:55:52
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.49 kb
#include <iostream>
#include <fstream>
#include <vector>

using namespace std;

ifstream f("deque.in");
ofstream g("deque.out");


int keys[5000005]; 
int elements[5000005];

template<typename T>
class Deque{

    private:
        vector<T> deque;

    public:

        void push_front(T x){
            deque.insert(deque.begin(), x);
        }

        void push_back(T x){
            deque.push_back(x);
        }

        void pop_back(){
            deque.pop_back();
        }

        void pop_front(){
            deque.erase(deque.begin());
        }

        T front(){
            return deque.front();
        }

        T back(){
            return deque.back();
        }

        size_t size(){
            return deque.size();
        }

        bool empty(){
            return deque.empty();
        }
};

int main()
{
	

    long long no_of_elements, interval, x, sum = 0, last = 1, last_index = 0;
    f >> no_of_elements >> interval;

    Deque<pair<long long, long long>> deque;



	for(long long i=1; i<=no_of_elements; i++){
		f >> x;
		elements[i] = x;
	}

    for(long long i=1; i<=no_of_elements; i++){

        while((last <= last_index && elements[i] <= elements[keys[last_index]])){
			last_index--;    
        }

		keys[++last_index] = i;

        if(keys[last] == i - interval) last++;

        if(i >= interval){ 
            sum += elements[keys[last]];
         }
    }

    g << sum;	

    return 0;
}