Pagini recente » Cod sursa (job #3002092) | Cod sursa (job #1025503) | Cod sursa (job #1660628) | Cod sursa (job #2190828) | Cod sursa (job #1507576)
# include <fstream>
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;
long long v[n], deq[n];
for (i=1; i<=n; i++)
{
f>>v[i];
}
prim=1; ulti=0; //deq este gol
for (i=1; i<=n; 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 elimin
if (i>=k)
sum+=v[deq[prim]];
}
g<<sum;
return 0;
}