Pagini recente » Cod sursa (job #2734446) | Cod sursa (job #170184) | Cod sursa (job #2609664) | Cod sursa (job #931848) | Cod sursa (job #1507583)
# include <fstream>
//# include <iostream>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
long long n, k, i, prim, ulti, sum=0;
int main()
{
f>>n>>k;
prim=1; ulti=0; //deq este gol
long long v[n], deq[n];
for (i=1; i<=n; i++)
{
f>>v[i];
while (prim<=ulti && v[i]<v[deq[ulti]]) //nu a ajuns la deq vid si mai pot scoate elem. din deq
ulti--;
deq[++ulti]=i; //pun poztia pe care se gaseste minimul
if (deq[prim]==i-k)
prim++; //daca nu se mai gaseste in secventa de k elem., il scot
if (i>=k)
sum+=v[deq[prim]];
}
g<<sum;
return 0;
}