Cod sursa(job #1845822)
Utilizator | Ionescu Teodor teoionescu | Data | 11 ianuarie 2017 21:45:02 |
---|---|---|---|
Problema | Deque | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.46 kb |
#include<fstream>
using namespace std;
typedef long long ll;
ifstream in("deque.in");
ofstream out("deque.out");
const int Nmax = 5000001;
int d[Nmax],st=1,dr;
int v[Nmax],N,K,x;
ll s;
int main(){
in>>N>>K;
for(int i=1;i<=N;i++) in>>v[i];
for(int i=1;i<=N;i++){
while(st<=dr && d[st]<=i-K) st++;
while(st<=dr && v[d[dr]]>v[i]) dr--;
d[++dr]=i;
if(i>=K) s+=v[d[st]];
}
out<<s<<'\n';
return 0;
}