Pagini recente » Cod sursa (job #1485714) | Cod sursa (job #504789) | Cod sursa (job #1951684) | Cod sursa (job #1138997) | Cod sursa (job #1507556)
# include <fstream>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
long n, k, i, prim, ulti;
int main()
{
f>>n>>k;
long v[n], deq[n], sum=0;
for (i=1; i<=n; i++)
{
f>>v[i];
}
prim=1; ulti=0;
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;
}