68990

Поняття черги і стека

Лекция

Информатика, кибернетика и программирование

Поняття стека Поняття черги У програмуванні поняття черги як динамічної структури даних використовують для моделювання процесів пов’язаних з почерговим виконанням деяких замовлень. Поняття стека Другий вид черги називають стеком.

Украинкский

2014-09-28

35.5 KB

1 чел.

Лекція № 19

Тема: Поняття черги і стека

План заняття:

1. Поняття черги.

2. Поняття стека

Поняття черги

У програмуванні поняття черги як динамічної структури даних використовують для моделювання процесів, пов'язаних з почерговим виконанням деяких замовлень. Над чергою визначені дві операції: введення елемента в чергу і вибір елемента з черги для обслуговування з вилученням із черги. Є такі два види черг, що відрізняються дисципліною обслуговування:

1)  черги з дисципліною обслуговування FIFO (First In -First Out) перший у чергу - перший з черги, тобто раніше буде обслужений той елемент, який раніше потрапив у чергу;

2)  черги з дисципліною обслуговування LIFO (Last In -First Out) останній у чергу - перший із черги, тобто першим буде обслужений той елемент, який останнім потрапив у чергу.

Поняття стека

Другий вид черги називають стеком. Для відображення стека використаємо введену раніше структуру - динамічний ланцюг ланок. У цьому випадку єдино доступною позицією вважатимемо першу ланку ланцюга, яку називають вершиною стека. Нульової ланки тепер не потрібно, а значення вказівника, що визначає весь стек, є вказівка на вершину стека. В кожній ланці є вказівка на наступну, значення вказівки останньої ланки є nil.

Отже, стек можна описати за допомогою таких типів:

type

TypeElm=Char;

Link=^Ls;

Ls=record

Elem: Char;

Next: Link;

end;

Stack=Link;

Тепер, використовуючи ці описи, стек як об'єкт програми можна ввести за допомогою опису змінної:

var

St: Stack;

Схематично стек зображено на рис. 1.

 ……….

 Рис 1. Стек

 Перед формуванням стека його треба зробити порожнім за допомогою присвоєння

St:=nil;

Працюючи зі стеком, найчастіше використовують дві процедури: введення елемента в стек і вибір елемента зі стека. Процедура введення в стек містить як формальні параметри вказівку на потрібний стек і значення елемента, який уводять у цей стек:

program Form7;

type

TypeElm=Char;

Link=^Ls;

Ls=record

Elem: Char;

Next: Link;

end;

Stack=Link;

procedure lnStack(var St: Stack; Elm: Char);

var Rb: Link;

begin

new(Rb);

Rb^.EIem:=Elm;

Rb^.Next:=St;

St:=Rb;

end;

begin

end.

Процедура вибору зі стека полягає у виборі елемента, що є в його вершині, і присвоєнні значення цього елемента деякій змінній, а також ліквідації першої ланки стека:

program Form8;

type

TypeElm=Char;

Link=^Ls;

Ls=record

Elem: Char;

Next: Link;

end;

Stack=Link;

procedure OutStack(var St: Stack; var a: Char);

var Rb: Stack;

begin

Rb:=St;

a:=St^.EIm;

St:=St^.Next;

Dispose(Rb)

end;

begin

end.

Це найпростіший варіант процедури вибору із стека. Досконалішою буде процедура, яка враховує можливість порожнього стека і видає в цьому випадку повідомлення про спробу вибору елемента з порожнього стека. Інше можливе вдосконалення - знищення першої ланки стека за допомогою процедури Dispose. В нашій процедурі OutStack, хоча вершина й переноситься на наступну ланку, попередня вершина залишається в пам'яті.


 

А также другие работы, которые могут Вас заинтересовать

67961. Патогенные простейшие. Возбудители лейшманиозов, токсоплазмозов, лямблиозов, трихомоноза и амебиаза 90 KB
  Снаружи простейшие окружены мембраной (пелликулой) - аналогом цитоплазматической мембраны клеток животных. Некоторые простейшие имеют опорные фибриллы. Цитоплазма и ядро соответствуют по строению эукариотическим клеткам: цитоплазма состоит из эндоплазматического ретикулума, митохондрий, лизосом...
67962. Методы микробиологической диагностики хламидиозов и микоплазмозов 100.5 KB
  Хламидии, относятся к облигатным внутриклеточным паразитам, имеющим кокковидную форму, грамотрицательны. Геном хламидий составляет не более 15% размера генома кишечной палочки. Хламидии не могут синтезировать высокоэнергетические соединения и обеспечивать собственные энергетические потребности...
67963. Микробиологическая диагностика риккетсиозов 97 KB
  Актуальность темы: Заболевания, вызываемые риккетсиями, называются риккетсиозами, они распространены во всех странах мира. До недавнего времени семейство риккетсий включало роды Rickettsia, Orienta, Erlichia, Coxiella. По современной класификации семейство Rickettsiaceae включает два рода...
67965. Санитарная микробиология 94.5 KB
  Цель: Освоение практических навыков определения санитарных показателей воды. Основными задачами санитарной микробиологии являются: Разработка и совершенствование микробиологических методов исследования объектов окружающей среды воды воздуха почвы пищевых продуктов предметов обихода...
67968. Клиническая микробиология. Госпитальные инфекции 67 KB
  Клиническая микробиология – это раздел частной медицинской микробиологии, посвященный изучению заболеваний, вызванных условно-патогенными микроорганизмами. Развитие подобных заболеваний связано со снижением иммунного статуса человека, развитием иммунодефицитных состояний, интенсивной антибиотикотерапией...
67969. Система управления базами данных Microsoft Access 2007. Создание базы данных 393.5 KB
  Перед созданием таблиц в СУБД необходимо для каждого поля столбца таблиц определить некоторые характеристики полужирным шрифтом выделены ключевые поля: Тематика Характеристики поля Поле Тип поля Списочный характер Возможные ограничения Индексируемость Обязательность заполнения Код тематики...