Nu aveti permisiuni pentru a descarca fisierul grader_test16.in
Cod sursa(job #667929)
Utilizator | Data | 23 ianuarie 2012 22:12:28 | |
---|---|---|---|
Problema | Deque | Scor | 60 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.39 kb |
#include<fstream>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int n,k,i,st,dr;
int a[5000010],deque[500010];
long long rez;
int main()
{
f>>n>>k;
for(i=1;i<=n;++i)
f>>a[i];
st=1;dr=0;
for(i=1;i<=n;++i)
{
while(st<=dr && a[i]<=a[deque[dr]])
--dr;
deque[++dr]=i;
if(deque[st]==i-k)
st++;
if(i>=k)
rez+=a[deque[st]];
}
g<<rez;
}