Cod sursa(job #1873628)
| Utilizator | Data | 9 februarie 2017 11:59:39 | |
|---|---|---|---|
| Problema | Deque | Scor | 25 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.53 kb |
#include <bits/stdc++.h>
using namespace std;
deque < pair <long long,long long> > q;
long long n,k;
int main()
{
int x,sum=0;
ifstream fin("deque.in");
fin>>n>>k;
for(int i=1;i<=n;i++){
fin>>x;
if(i-k>=q.front().second) q.pop_front();
while(!q.empty()&&q.back().first>=x) q.pop_back();
q.push_back(make_pair(x,i));
if(i>=k) sum+=q.front().first;
}
fin.close();
ofstream fout("deque.out");
fout<<sum<<'\n';
fout.close();
return 0;
}
