Pagini recente » Cod sursa (job #53920) | Cod sursa (job #2127250) | Cod sursa (job #701920) | Cod sursa (job #2113869) | Cod sursa (job #561796)
Cod sursa(job #561796)
#include <cstdio>
#include <deque>
using namespace std;
int n,k,a[5000002];
deque <int> D;
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%d%d",&n,&k);
int x;
long long sum=0;
for(int i=1;i<=n;++i)
{
scanf("%d",&x);
a[i]=x;
while(D.size()>0&&D.back()>x)
D.pop_back();
D.push_back(x);
if(i-k>=0)
{
if(i==k);
else if(D.front()==a[i-k])
D.pop_front();
sum+=D.front();
}
}
printf("%lld\n",sum);
return 0;
}