![](/logo_grey.gif)
Последние записи
- Как в Python+Selenium webdriver открыть новую вкладку в уже открытом браузере?
- Lazarus, проверка существования строки таблице
- BASM и record, обращение к полям записи
- Web PHP Framework Symfony
- Относительный путь для вывода картинки на html странице
- Массовое открытие гиперссылок в браузере
- Скопировать значение строки из таблицы в textarea
- Рамки для страниц отчетов
- Вывод StdOut консоли в TMemo
- Чтение из файла большого размера (нехватка памяти)
![](http://programmersclub.ru/slurm3.jpg)
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
![](http://programmersclub.ru/katajpg.jpg)
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
2nd
Май
Связанные списки в Паскаль/Delphi
Posted by Chas under Пост-обзор
Хотелось бы понять как это все работает, поэтому если не сложно объясните плз «для чайника»
Serge_Bliznykov:
вот, примерно как надо (рекомендую разобрать и понять принципы..):
Type
tp=^el;
el=record
slovo:string;
next:tp;
prev:tp;
end;
var
first, last : tp;
procedure tpInit; { инициализация списка }
begin
first := nil; last := nil;
end;
procedure Print_forward(start: tp); { процедура печати элементов с первого(начало) }
begin
if start = nil then writeln('List not init')
else
begin
while (start <> nil) do
begin
write(start^.slovo, ' ');
start := start^.next;
end;
WriteLn;
end;
end;
procedure Print_back(start: tp); { процедура печати элементов с последнего(начало) }
begin
if start = nil then writeln('List not init')
else
begin
while (start <> nil) do
begin
write(start^.slovo, ' ');
start := start^.prev;
end;
WriteLn;
end;
end;
procedure tpInsert( s : string); {процедура вставки элементов в конец списка(информационная часть) }
var
p : tp;
begin
new(p);
p^.slovo := s;
p^.next := nil;
if (first=nil) and (last=nil) {если пустой список} then
begin
first := p;
first^.prev := nil;
end
else {список не пуст, добавляем элемент в конец и корректируем указатели}
begin
last^.next := p;
p^.prev := last;
end;
last := p;
end;
{тело программы}
begin
tpInit;
tpInsert('Hello');
tpInsert('Crazy');
tpInsert('World');
WriteLn('--- печать списка в прямом направлении ---');
Print_forward(first);
WriteLn('--- печать списка в обратном направлении ---');
Print_back(last);
end.
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
![пеллетные котлы](http://programmersclub.ru/respective.jpg)
пеллетные котлы
![пеллетный котел](http://programmersclub.ru/emtas.jpg)
Пеллетный котел Emtas
![форум программистов](http://programmersclub.ru/banf336х280.gif)
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)