Опашка (абстрактен тип данни): Разлика между версии

Изтрито е съдържание Добавено е съдържание
м без 'досега', неакт.
м Bot: Automated text replacement (- въпреки, че + въпреки че )
Ред 5:
== Статична реализация ==
[[Файл:QUEUE-STATIC.jpg|рамка|дясно|Циклично движение на опашка в масив.]]
Статичната опашка се реализира с помощта на [[Масив (програмиране)|масив]]. В даден момент началото и краят на опашката сочат към определени индекси от масива. Когато се добавя нов елемент той се поставя на индекса след края на опашката и краят вече сочи към новия елемент. Когато се премахва началото на опашката, елементът на началния индекс се изтрива и началото започва да сочи към следващия индекс. По този начин с добавяне и извличане на елементи от опашката тя се движи към края на масива. В даден момент краят на опашката достига до последния индекс на масива и се оказва, че размерът на масива не е достатъчен въпреки, че опашката не запълва всичките му елементи. За да се реши този проблем при следващото добавяне на елемент в края на опашката, той се поставя на началния индекс на масива. По този начин се свързват началото и края на масива, и опашката може да обикаля безкрайно в него. В началото индексите за начало и край сочат нулевия елемент. В процеса, ако отново се окажат равни това може да означава две неща:
:- ако равенството се е получило след премахване на елемент, опашката е останала празна.
:- ако равенството се е получило след добавяне на елемент, то опашката е препълнена.