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, хоча вершина й переноситься на наступну ланку, попередня вершина залишається в пам'яті.


 

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

108. Особливості роботи редакторів растрової та векторної графіки 615.5 KB
  Редактор растрової графіки Adobe Photoshop, програма верстки Adobe PageMaker, редактор векторної графіки Corel DRAW. Найбільш широке поширення на комп’ютерах IBM PC одержали монітори типу MDA, CGA, Hercules, EGA і VGA.
109. Загальна теорія лінійних операторів 598.5 KB
  Лінійні оператори в комплексному Евклідовому просторі. Основний вигляд матриці лінійного оператора. Одним з найважливіших моментів у створенні основ цих математичних дисциплін є введення поняття функція.
110. Расчёт технологии прокатки листа 16х2000х5000 из стали 3 на стане 2800 ОАО АМК 518 KB
  Расчет режима обжатий в черновой и чистовой клетях. Расчет скоростного режима прокатки на клети Кварто. Определение допустимого момента при прокатке на клети Дуо. Определение допустимых усилий на валках.
111. Разработка экономических характеристик ООО 7-С Ритейл 89.11 KB
  Изучение и анализ всех видов деятельности предприятия в условиях перехода к рыночной экономике. Анализ экономических процессов, выбор и обоснование управленческих решений в конкретных производственных ситуациях.
113. Теория международного маркетинга 1.61 MB
  Процессы, происходящие на мировых рынках, имеют безусловно универсальный характер. И хотя естественным представляется утверждение. Технология внедрения фирмы на международные рынки требует рассмотрения факторов и способов вхождения на внешние рынки.
114. Управління системою маркетингової діяльності на підприємстві ТОВ Компанія Юнівест Маркетинг 807.92 KB
  Теоретична інформація та методологічні підходи до проблеми організації управління маркетинговою діяльністю на підприємстві. Техніко-економічний аналіз та маркетинговий аналіз зовнішнього і внутрішнього середовища.
116. Рекламная деятельность: организация, планирование, оценка эффективности 1.42 MB
  Организация рекламной деятельности рекламодателем. Рекламу изучают и как часть процесса продажи товара, и как коммуникацию, и как часть маркетинга, и как искусство. Средства массовой информации или средства размещения информации.