Pagini recente » Cod sursa (job #579370) | Cod sursa (job #1785291) | Cod sursa (job #1785295) | Cod sursa (job #1785308) | Cod sursa (job #846276)
Cod sursa(job #846276)
#include<fstream>
#include<queue>
using namespace std;
const int Nmax = 5000001;
ifstream f("deque.in");
ofstream g("deque.out");
int N, K, V[Nmax];
deque<int> D;
long long rez;
int main() {
int i;
f>>N>>K;
for(i=1; i<=N; ++i)
f>>V[i];
for(i=1; i<=N; ++i) {
while(!D.empty() && V[D.back()] >= V[i])
D.pop_back();
D.push_back(i);
if(D.front() == i-K)
D.pop_front();
if(i>=K)
rez+=V[D.front()];
}
g<<rez<<"\n";
f.close(); g.close();
return 0;
}