Студопедия — Алгоритм удаления звена из очереди
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Алгоритм удаления звена из очереди






Пусть очередь не пуста (no! =NULL). Изобразим ее схематически:

Рисунок 13 - Очередь

Приступим к удалению звена. Напомним, что звено удаляется из очереди из ее начала.

1. Сохраним удаляемый элемент:

klad = (*no).elem; //первый элемент очереди

// сохранен в переменной klad

Рисунок 14 - Сохранение удаляемого элемента

2. Сохраним указатель на удаляемый элемент и " перенастроим" указатель на начало очереди:

q = no; // сохранение указателя на удаляемый элемент

no = (*no).sled; // присваивание указателя начала

// очереди следующему элементу

Рисунок 15 –«Перенастройка» указателя на начало очереди

3. Теперь необходимо включить в список свободной памяти удаленное из очереди звено с помощью вызова функции:

delete q; //удаление звена очереди

Рисунок 16 - Возврат памяти

Запишем приведенную схему в виде функции на языке C++:

void YDALENIE (node *no, node *ko, int klad)

// Удаление звена из очереди, определенной указателями //*no и *ko. Значение информационного поля //удаленного звена

// сохраняется в параметре klad.

{// открытие тела функции YDALENIE

node *q; // указатель на удаляемое звено

 

if (*no==NULL)// если очередь пуста

cout< < " Удалить нельзя, так как очередь пуста! \n";

// вывод текста на дисплей

else // иначе

{ // открытие else

*klad = (*no).elem; //сохранение первого элемента в klad

q = *no; // сохранение указателя на удаляемый элемент

//в q

*no = (*no).sled; // присваивание указателя начала

// очереди следующему элементу

deleteq; // удаление первого звена

} // закрытие else

}// закрытие тела функции YDALENIE

 







Дата добавления: 2014-11-10; просмотров: 508. Нарушение авторских прав; Мы поможем в написании вашей работы!



Аальтернативная стоимость. Кривая производственных возможностей В экономике Буридании есть 100 ед. труда с производительностью 4 м ткани или 2 кг мяса...

Вычисление основной дактилоскопической формулы Вычислением основной дактоформулы обычно занимается следователь. Для этого все десять пальцев разбиваются на пять пар...

Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...

Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...

Различие эмпиризма и рационализма Родоначальником эмпиризма стал английский философ Ф. Бэкон. Основной тезис эмпиризма гласит: в разуме нет ничего такого...

Индекс гингивита (PMA) (Schour, Massler, 1948) Для оценки тяжести гингивита (а в последующем и ре­гистрации динамики процесса) используют папиллярно-маргинально-альвеолярный индекс (РМА)...

Методика исследования периферических лимфатических узлов. Исследование периферических лимфатических узлов производится с помощью осмотра и пальпации...

Классификация холодных блюд и закусок. Урок №2 Тема: Холодные блюда и закуски. Значение холодных блюд и закусок. Классификация холодных блюд и закусок. Кулинарная обработка продуктов...

ТЕРМОДИНАМИКА БИОЛОГИЧЕСКИХ СИСТЕМ. 1. Особенности термодинамического метода изучения биологических систем. Основные понятия термодинамики. Термодинамикой называется раздел физики...

Травматическая окклюзия и ее клинические признаки При пародонтите и парадонтозе резистентность тканей пародонта падает...

Studopedia.info - Студопедия - 2014-2024 год . (0.009 сек.) русская версия | украинская версия