Mai intai trebuie sa te autentifici.
Cod sursa(job #783689)
Utilizator | Data | 3 septembrie 2012 16:25:41 | |
---|---|---|---|
Problema | Deque | Scor | 30 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.48 kb |
#include<iostream>
#include<fstream>
#include<deque>
using namespace std;
int a[5000012],n,k;
long long sol;
deque <int > d;
int main(void)
{
fstream f,g;
f.open("deque.in",ios::in);
g.open("deque.out",ios::out);
f>>n>>k;
int i;
for(i=1;i<=n;i++)
f>>a[i];
for (i=1;i<=n;i++)
{
while( !d.empty() && d.back()>=a[i])
d.pop_back();
d.push_back(a[i]);
if (i>k)
if (d.front()==a[i-k])
d.pop_front();
if (i>=k)
sol+=d.front();
}
g<<sol;
}