Cod sursa(job #1774128)
| Utilizator | Data | 8 octombrie 2016 16:48:30 | |
|---|---|---|---|
| Problema | Deque | Scor | 60 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.44 kb |
#include <fstream>
#include <deque>
using namespace std;
ifstream fi("deque.in");
ofstream fo("deque.out");
int n,k,i,a[5000000];
long long sol;
deque<int> d;
int main()
{fi>>n>>k;
for(i=1;i<=n;i++) fi>>a[i];
for(i=1;i<=n;i++)
{
while(!d.empty() and a[d.back()]>=a[i]) d.pop_back();
while(!d.empty() and d.front() < i-k+1) d.pop_front();
d.push_back(i);
if(i>=k) sol+=a[d.front()];
}
fo<<sol;
return 0;
}
