Cod sursa(job #2075421)
Utilizator | Data | 25 noiembrie 2017 13:47:44 | |
---|---|---|---|
Problema | Deque | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.63 kb |
#include <fstream>
using namespace std;
long long v[5000005];
int st[5000005];
ifstream in("deque.in");
ofstream out("deque.out");
int main()
{
int n,k,left,right,i;
long long sum=0;
in>>n>>k;
for(i=1;i<=n;i++)
{
in>>v[i];
if(i==1)
{
left=right=1;
st[1]=1;
}
else
{
while(v[st[right]]>v[i] && right>=left)
right--;
right++;
st[right]=i;
if(st[left]<=i-k) left++;
}
if(i>=k) sum+=v[st[left]];
}
out<<sum<<'\n';
return 0;
}