Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лекции СД.doc
Скачиваний:
213
Добавлен:
19.03.2015
Размер:
1.81 Mб
Скачать
      1. 3. Моделирование работы стека

Модуль содержит вариант реализации стека на структуре данных «вектор». Стек расширяется в сторону уменьшения адресов. Указатель стека всегда указывает на первый свободный элемент. Перед использованием модуля должен быть определен предельный размер стека и структура элемента данных стека.

unit Stack;

Interface

const stsize = 10; { предельный размер стека }

type data = ...; { элементы могут иметь любой тип }

procedure StackInit;

procedure StackClr;

function StackPush(a: data): Boolean;

function StackPop(var a: data): Boolean;

function StackSize: Integer;

Implementation

var sta: array[1..stsize] of data; { данные стека }

{ Указатель на вершину стека,

работает на префиксное вычитание }

top: Integer;

{ инициализация - на начало }

procedure StackInit;

begin

top:=stsize;

end;

{ очистка = инициализация }

procedure StackClr;

begin

top:=stsize;

end;

{ занесение элемента в стек }

function StackPush(a: data): Boolean;

begin

if top = 0 then

StackPush:=False else

begin

{ занесение, затем - коррекция указателя }

sta[top]:=a;

top:=top-1;

StackPush:=True;

end;

end;

{ выборка элемента из стека }

function StackPop(var a: data): Boolean;

begin

if top = stsize then

StackPop:=False else

begin

{ коррекция указатель, затем - выборка }

top:=top+1;

a:=sta[top];

StackPop:=True;

end;

end;

function StackSize: Integer; { определение размера }

begin

StackSize:=stsize-top;

end;

end.

Модуль содержит вариант реализации стека на односвязном линейном списке.

unit stack;

Interface

type data = ...; { элементы могут иметь любой тип }

procedure StackInit;

procedure StackClr;

function StackPush(a: data): Boolean;

function StackPop(var a: data): Boolean;

function StackSize: Integer;

Implementation

type

stptr = ^stit; { указатель на элемент списка }

stit = record { элемент списка }

inf : data; { данные }

next: stptr; { указатель на следующий элемент }

end;

var

top: stptr; { указатель на вершину стека }

stsize: LongInt; { размер стека }

{ инициализация - список пустой }

procedure StackInit;

begin

top:=nil;

stsize:=0;

end;

{ очистка - освобождение всей памяти }

procedure StackClr;

var x: stptr;

begin

{ перебор элементов до конца списка и их уничтожение }

while top <> nil do

begin

x:=top;

top:=top^.next;

Dispose(x);

end;

stsize:=0;

end;

function StackPush(a: data): Boolean; { занесение в стек }

var x: stptr;

begin

{ если нет больше свободной памяти –

отказ; использовать только для BP 7.0 }

if MaxAvail < SizeOf(stit) then

StackPush:=False else

{ выделение памяти для элемента и заполнение информационной части }

begin

New(x);

x^.inf:=a;

{ новый элемент помещается в голову списка }

x^.next:=top;

top:=x;

stsize:=stsize+1; { коррекция размера }

StackPush:=True;

end;

end;

function StackPop(var a: data): Boolean; { выборка элемента из стека }

var x: stptr;

begin

{ список пуст - стек пуст }

if top = nil then

StackPop:=False else

begin

{ выборка информации из первого элемента списка }

a:=top^.inf;

{ первый элемент исключается из списка, освобождается память }

x:=top;

top:=top^.next;

Dispose(x);

stsize:=stsize-1; { коррекция размера }

StackPop:=True;

end;

end;

function StackSize: Integer; { определение размера стека }

begin

StackSize:=stsize;

end;

end.