Pagini recente » Diferente pentru utilizator/pauldb intre reviziile 65 si 123 | Profil MrPetcu | Profil yggar | Cod sursa (job #2679721) | Cod sursa (job #1221887)
#include <fstream>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int v[5000001],deq[5000001],Front,bacK,n,k;
long long sol;
int main()
{
f>>n>>k;
for(int i=1;i<=n;i++)
f>>v[i];
Front=1;bacK=0;
for(int i=1;i<=n;i++)
{
while(Front<=bacK && v[i]<=v[deq[bacK]])
bacK--;
deq[++bacK]=i;
if(deq[Front]==i-k)
Front++;
if(i>=k)
sol=sol+v[deq[Front]];
}
g<<sol;
return 0;
}