Pagini recente » Cod sursa (job #1233506) | Cod sursa (job #3155231) | Cod sursa (job #2292041) | Cod sursa (job #718627) | Cod sursa (job #2299322)
#include <iostream>
#include <fstream>
using namespace std;
int t[5000000],dq[5000003],i,k,j,n,p,u;
void adauga(int poz)
{
if(i>=k&&dq[p]==i-k)p++;
while(u>=p&&t[dq[u]]>t[poz])u--;
u++;
dq[u]=poz;
}
int main()
{
ifstream fin("deque.in");
ofstream fout("deque.out");
fin>>n>>k;
for(i=1;i<=n;i++)
fin>>t[i];
p=1;
u=0;
long long int sum=0;
for(i=1;i<=k;i++)
{
adauga(i);
}
sum+=t[dq[1]];
for(i=k+1;i<=n;i++)
{
adauga(i);
sum+=t[dq[p]];
}
fout<<sum;
}