Pagini recente » Istoria paginii utilizator/andreea.m | Diferente pentru problema/pluton intre reviziile 2 si 26 | I. Vopsire | Cod sursa (job #2715956) | Cod sursa (job #2627515)
#include <iostream>
#include<fstream>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int deq[5000001];
int v[5000001];
int main()
{
int n,k,i,ultimul=0,primul=1;
long long suma=0;
f>>n>>k;
for (i =1; i<=n; i++)
f>>v[i];
for (i=1; i<=n; i++)
{
while (primul<=ultimul&&v[i]<=v[deq[ultimul]])
ultimul--;
deq[++ultimul] = i;
if (deq[primul] == i - k)
primul++;
if (i>=k)
suma+=v[deq[primul]];
//for(int j=1; j<=n; j++)cout<<deq[j]<<" ";cout<<"\n";
}
g<<suma;
return 0;
}