Индивидуальные и групповые автопоилки: для животных. Схемы и конструкции...
Индивидуальные очистные сооружения: К классу индивидуальных очистных сооружений относят сооружения, пропускная способность которых...
Топ:
Методика измерений сопротивления растеканию тока анодного заземления: Анодный заземлитель (анод) – проводник, погруженный в электролитическую среду (грунт, раствор электролита) и подключенный к положительному...
Когда производится ограждение поезда, остановившегося на перегоне: Во всех случаях немедленно должно быть ограждено место препятствия для движения поездов на смежном пути двухпутного...
Процедура выполнения команд. Рабочий цикл процессора: Функционирование процессора в основном состоит из повторяющихся рабочих циклов, каждый из которых соответствует...
Интересное:
Лечение прогрессирующих форм рака: Одним из наиболее важных достижений экспериментальной химиотерапии опухолей, начатой в 60-х и реализованной в 70-х годах, является...
Что нужно делать при лейкемии: Прежде всего, необходимо выяснить, не страдаете ли вы каким-либо душевным недугом...
Уполаживание и террасирование склонов: Если глубина оврага более 5 м необходимо устройство берм. Варианты использования оврагов для градостроительных целей...
Дисциплины:
|
из
5.00
|
Заказать работу |
Содержание книги
Поиск на нашем сайте
|
|
|
|
Ссылочная реализация очереди принципиально не отличается от ссылочной реализации стека, однако необходимость выполнять вставку и удаление на разных концах несколько усложняют детали. Во-первых, нужно хранить два дополнительных указателя — на хвост и голову очереди (обозначим их head и tail, как и в случае непрерывной реализации на массиве). Во-вторых, каждый элемент содержит указатель на следующий добавленный в очередь элемент, а не на предыдущий, как в стеке. Самый последний элемент очереди еще не имеет следующего элемента, поэтому содержит пустой указатель. Особенности ссылочной реализации очереди показаны на рисунке 2.5.

Рис.2.5. Представление очереди при помощи связного списка
Структура элемента очереди совпадает со структурой элементов стека с точностью до обозначений:
struct item //структура каждого элемента очереди
{ type_of_data data; // данные
item *next; // указатель на следующий элемент
};
Полное определение структуры queue приводить не будем, поскольку оно аналогично приведенной выше непрерывной реализации очереди (отсутствует только массив data). Можно самостоятельно определить структуру (или класс) очереди на основе шаблонов.
Интерес представляют операции добавления и удаления элементов, поскольку они выполняются немного иначе, чем аналогичные операции со стеком.
При добавлении элемента в хвост очереди достаточно (рис. 2.6):
· захватить под него память, заполнить информационную часть данными, указателю присвоить пустое значение;
· заполнить указующую часть элемента, бывшего последним (хвостом) в очереди — он теперь будет предпоследним и должен указывать на новый элемент;
· присвоить указателю на хвост указатель на новый элемент — он теперь будет хвостом очереди.

Рис.2.6. Добавление элемента в очередь
В соответствии с данным алгоритмом функция добавления имеет вид:
void queue::enqueue (type_of_data x)
{ item *i=new item; i->data=x; i->next=NULL; //элемент создан
if (isnull())//добавление первого элемента в пустую очередь
{ head=tail=i;
}
else // добавление в непустую очередь
{ tail->next=i; //последний элемент стал предпоследним
tail=i; // обновили указатель на хвост
}
}
Удаление из головы очереди также выполняется просто — достаточно изменить указатель на голову и освободить память, которую занимал элемент, воспользовавшись буферной переменной (рис.2.7).

Рис.2.7.Удаление (извлечение) элемента из очереди
void queue::dequeue ()
{ if (isnull()) { cerr << "Очередь пуста"; exit(1); }
item *i=head->next;//запомнили указатель на второй элемент
delete head; head=i;//удалили голову и изменили указатель
}
Полную очистку всей очереди можно реализовать, например, так:
void queue::makenull()
{ while (!isnull()) dequeue(); // удаляем элементы по порядку
}
|
|
|
Папиллярные узоры пальцев рук - маркер спортивных способностей: дерматоглифические признаки формируются на 3-5 месяце беременности, не изменяются в течение жизни...
Двойное оплодотворение у цветковых растений: Оплодотворение - это процесс слияния мужской и женской половых клеток с образованием зиготы...
Общие условия выбора системы дренажа: Система дренажа выбирается в зависимости от характера защищаемого...
История развития пистолетов-пулеметов: Предпосылкой для возникновения пистолетов-пулеметов послужила давняя тенденция тяготения винтовок...
© cyberpedia.su 2017-2026 - Не является автором материалов. Исключительное право сохранено за автором текста.
Если вы не хотите, чтобы данный материал был у нас на сайте, перейдите по ссылке: Нарушение авторских прав. Мы поможем в написании вашей работы!