Strukturë ku elementet “palohen” një mbi një.
Në stack lejohet manipulimi me vetëm elementin më të sipërm (ang. top).
Operacionet bazike mbi stack:
Operacioni Push
Shto element të ri në maje të stackut.
Operacioni Pop
Largo elementin nga maja e stackut.
Stack është implementim i parimit LIFO: last-in, first-out.
Elementi i fundit i shtuar në stack del i pari.
Detyrë: Të implementohet klasa Stack<T>
me veprimet kryesore push
dhe pop
, si dhe veprimet tjera ndihmëse.
Në librarinë standarde stack ofrohet me tipin stack<T>
.
Detyrë: Të përdoret klasa e gatshme stack<T>
dhe të krahasohet me implementimin nga detyra e kaluar.
Strukturë ku elementet “renditen” njëra pas tjetrës.
Në queue elementet e reja shtohen në fund, ndërsa largimi bëhet nga fillimi.
Analogji me radhët e pritjes në shitore, aeroport, bankë, etj.
Operacionet bazike mbi queue:
Operacioni Enqueue
Shto element të ri në fund të radhës.
Operacioni Dequeue
Largo elementin nga fillimi i radhës.
Radha (queue) është implementim i parimit FIFO: first-in, first-out.
Elementi më i hershëm i shtuar në radhë del i pari.
Detyrë: Të implementohet klasa Queue<T>
me veprimet kryesore enqueue
dhe dequeue
, si dhe veprimet tjera ndihmëse.
Në librarinë standarde radha ofrohet me tipin queue<T>
.
Detyrë: Të përdoret klasa e gatshme queue<T>
dhe të krahasohet me implementimin nga detyra e kaluar.