Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 21.11.2008, 19:52
Pirate_XP Pirate_XP вне форума
Прохожий
 
Регистрация: 21.11.2008
Сообщения: 3
Репутация: 10
Сообщение Pascal. Стеки

Привет Всем !
Воник такой вопрос, Как понять стек с неизменным указателем вершины, и как его можно реализовать ?

Спасибо)
Ответить с цитированием
  #2  
Старый 21.11.2008, 20:50
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,034
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

А стек он всегда и есть с постоянным указателем вершины.
Стек - это очередь типа FILO.

Реализуется на любом списковом классе, да хоть на массиве.
Суть стека в том, что в каком порядке ты теда засовываешь данные, то в таком же и вынимаешь.

Например, для типа Integer реализация стека будет примерно такая:

Код:
type
  TIntStack = class
  private
    FItems : TList;
  public
    constructor Create;
    destructor Destroy; override;
  
    procedure Push(AItem : Integer);
    function Pop : Integer;
  end;

constructor TIntStack.Create;
begin
  inherited;
  FItems := TList.Create;
end;

destructor TIntStack.Destroy;
begin
  FItems.Free;
  inherited;
end;

procedure TIntStack.Push(AData : Integer);
begin
  FItems.Insert(0,Pointer(AData));
end;

function TIntStack.Pop : Integer;
begin
  If FItems.Count = 0 Then Raise Exception.Create('Stack is empty');
  Result := Integer(FItems[0]);
  FItems.Delte(0);
end;

1. Могут быть опечатки, т.к. писал здесь.
2. Специально сделал для отдельного типа. Если надо - переделай для типа Variant.
Ответить с цитированием
  #3  
Старый 21.11.2008, 20:51
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,034
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Или тебе надо на связанных списках сделать? Очень уж нехочется возиться с указателями. Принцип примерно такой же, тем более, что все равно для удобства пользования надо оборачивать все в класс, а тогда детали реализации не так важны.
Ответить с цитированием
  #4  
Старый 21.11.2008, 22:12
Pirate_XP Pirate_XP вне форума
Прохожий
 
Регистрация: 21.11.2008
Сообщения: 3
Репутация: 10
По умолчанию

Да задача сделать это в паскале))
Но кажется я уже нашел пример, спасибо тебе
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 19:04.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter