Компонентный Паскаль/Связанный список: различия между версиями

Материал из Викиучебника — открытых книг для открытого мира
Содержимое удалено Содержимое добавлено
Строка 10: Строка 10:


== Пример использования двусвязного списка ==
== Пример использования двусвязного списка ==
Задача создания двусвязного списка разбивается на несколько простых подзадач.

=== Создание элемента двусвязного списка ===
Для начала создадим тип данных, соответствующей нашей задаче -- элемент двусвязного списка . Примерный код представлен ниже:
Для начала создадим тип данных, соответствующей нашей задаче -- элемент двусвязного списка . Примерный код представлен ниже:
<source lang="oberon2">
<source lang="oberon2">

Версия от 13:02, 20 апреля 2015

Понятие о связанном списке

Что такое список -- знают все из повседневной жизни. Это лист бумаги, который содержит пункты, например, того, что нужно купить в магазине. Аналога связанного списка[1] в жизни нет. С большой натяжкой связанным списком в жизни можно назвать алгоритм схемы в виде блок-схем[2]. В блок-схемах каждый последующий блок, связан с предыдущим. но в блок-схемам могут быть побочные связи, а в связанных списках их нет.

Связанный список, как и блок-схема, в каждом элементе списка содержит полезную информацию, и также содержит служебную информацию. Эта информация, может быть представлена указателем на следующий элемент, точно такой же по структуре. Такой список называется односвязным. Может быть в элементе указатель на предыдущую структуру. Такой список называется двусвязным. Могут быть ещё какие-то указатели на совсем другие структуры, по необходимости.

При использовании односвязного списка надо быть очень внимательным, чтобы цепочка не разорвалась, т. к. информация за разрывом будет потеряна. При двусвязных списках вероятность такого неприятного события сохраняется, но существенно ниже[3].

Пример использования двусвязного списка

Задача создания двусвязного списка разбивается на несколько простых подзадач.

Создание элемента двусвязного списка

Для начала создадим тип данных, соответствующей нашей задаче -- элемент двусвязного списка . Примерный код представлен ниже:

TYPE
	TDblElem = RECORD (* Элемент двусвязного списка *)
		value : INTEGER; (* полезная информация *)
		first : BOOLEAN;  (* признак первого элемента в списке *)
		Last  : BOOLEAN;  (* признак последнего элемента в списке *)
		backward: POINTER TO TDblElem; (* указатель на предыдущий элемент *)
		forward: POINTER TO TDblElem; (* указатель на следующий элемент *)
	END;

Примечания

  1. Связный список не единственная структура в подобном роде. Варианты списков можно посмотреть по ссылке в этом пункте примечания. Допустимо использование названий структуры как "Связаный список", так и "Связанный список".
  2. Блок-схема -- это одна из технологий разработки программного обеспечения (ПО), которая была принята в качестве стандарта на заре компьютерной эпохи. Необходимость в блок-схемах естественно вытекала из-за невыразительности языков программирования. Очень часто в государственных организациях до наших дней можно встретить алгоритмы действий в виде блок-схем на стенах. Блок-схемы несколько архаичны, но например, такой визуальный графический язык, как ДРАКОН ещё не сказал своего слова. Создатели космического корабля "Буран" это подтверждают.
  3. Следует помнить о том, что связанный список для хранения информации может иметь КПД всего 11%: 4 байта на указатель на следующий элемент, 4 байта на предыдущий элемент, и только 1 байт на переменную типа BYTE. Соотношение полезной информации к общей как 1 к 9, что и даёт всего 11%.