Pagini recente » Cod sursa (job #2888228) | Cod sursa (job #1368070) | Cod sursa (job #1809952) | Cod sursa (job #946364) | Cod sursa (job #333226)
Cod sursa(job #333226)
#include<fstream>
using namespace std;
ifstream in("deque.in");
ofstream out("deque.out");
int n,k,v[5000001],d[5000001],st,dr;
void stanga(int i)
{
if(i-k==d[st])
++st;
}
void dreapta(int i)
{
while(st<=dr && v[d[dr]]>=v[i])
--dr;
}
int main()
{
in>>n>>k;
st=1;dr=0;
int i;
long long s=0;
for(i=1;i<=n;i++)
in>>v[i];
for(i=1;i<=k;i++)
{
dreapta(i);
d[++dr]=i;
}
s=v[d[st]];
for(;i<=n;i++)
{
stanga(i);
dreapta(i);
d[++dr]=i;
s+=v[d[st]]
;
}
out<<s;
in.close();
out.close();
return 0;
}