Список (информатика)

Материал из свободной русской энциклопедии «Традиция»
(перенаправлено с «Список (структура данных)»)
Перейти к: навигация, поиск

Спи́сок — упорядоченная последовательность элементов данных, воспринимаемая как особая контейнерная структура данных. В качестве элементов списка могут выступать любые другие элементы данных, в том числе и сами списки.

Определение[править]

При помощи нотации метода синтаксически-ориентированного конструирования Ч. Хоара определение списка можно записать следующим образом: $$List(A) = NIL + (A \times List(A))$$ $$prefix = \text{constructor}$$\(List(A)\) $$head, tail = \text{selectors}$$\(List(A)\) $$null, nonnull = \text{predicates}$$\(List(A)\) $$NIL, nonNIL = \text{parts}$$\(List(A)\)

Первая строка данного определения обозначает, что список элементов типа \(A\) (говорят: «список над \(A\)») представляет собой размеченное объединение пустого списка и декартова произведения атома типа \(A\) со списком над \(A\). Для создания списков используются два конструктора (вторая строка определения), первый из которых создаёт пустой список, а второй — непустой соответственно. Вполне понятно, что второй конструктор получает на вход в качестве параметров некоторый атом и список, а возвращает список, первым элементом которого является исходный атом, а остальными — элементы исходного списка. То есть получается префиксация атома к списку, с чем и связано такое наименование конструктора. Здесь необходимо отметить, что пустой список \([]\) не является атомом, а потому не может префиксироваться. С другой стороны, пустой список является как бы нулевым элементом для конструирования списков, поэтому любой список содержит в самом своём конце именно пустой список — с него начинается конструирование.

Третья строка определяет селекторы для списка, то есть операции для доступа к элементам внутри списка. Селектор \(head\) получает на вход список и возвращает первый элемент этого списка, то есть типом результата является тип \(A\). Этот селектор не может получить на вход пустой список — в этом случае результат операции неопределён. Селектор \(tail\) возвращает список, полученный из входного в результате отсечения его головы (первого элемента). Этот селектор также не может принимать на вход пустой список, так как в этом случае результат операции неопределён. При помощи этих двух операций можно достать из списка любой элемент. Например, чтобы получить третий элемент списка (если он имеется), необходимо последовательно два раза применить селектор \(tail\), после чего применить селектор \(head\). Другими словами, для получения элемента списка, который находится на позиции \(n\) (начиная с \(0\) для первого элемента, как это принято в программировании), необходимо \(n\) раз применить селектор \(tail\), после чего применить селектор \(head\).

Четвёртая строка определения описывает предикаты для списка, то есть функции, возвращающие булевское значение в зависимости от некоторых условий. Первый предикат возвращает значение \(true\) в случае, если заданный список пуст. Второй предикат действует наоборот. Наконец, пятая строка описывает части списка, которые, как уже сказано, представляют собой пустой и непустой списки.

Свойства[править]

У определённой таким образом структуры данных имеются некоторые свойства:

  • Размер списка — количество элементов в нём, исключая последний «нулевой» элемент, являющийся по определению пустым списком.
  • Тип элементов — тот самый тип \(A\), над которым строится список; все элементы в списке должны быть этого типа.
  • Отсортированность — список может быть отсортирован в соответствии с некоторыми критериями сортировки (например, по возрастанию целочисленных значений, если список состоит из целых чисел).
  • Возможности доступа — некоторые списки в зависимости от реализации могут обеспечивать программиста селекторами для доступа непосредственно к заданному по номеру элементу.
  • Сравниваемость — списки можно сравнивать друг с другом на соответствие, причём в зависимости от реалиации операция сравнения списков может использовать разные технологии.

Как должно быть понятно из названия рассматриваемой структуры данных, списки используются для хранения наборов однотипных элементов. Такие элементы могут быть отсортированы для использования в функциях поиска или функциях для быстрой вставки новых элементов в список.

Списки в языках программирования[править]

Функциональные языки[править]

Язык Haskell[править]

Язык Lisp[править]

Императивные языки[править]

См. также[править]