Полиморфизм (информатика)
- 1 year ago
- 0
- 0
В информатике , спи́сок ( англ. list ) — это абстрактный тип данных , представляющий собой упорядоченный набор значений , в котором некоторое значение может встречаться более одного раза. Экземпляр списка является компьютерной реализацией математического понятия конечной последовательности . Экземпляры значений, находящихся в списке, называются элементами списка ( англ. item, entry либо element ); если значение встречается несколько раз, каждое вхождение считается отдельным элементом.
Термином список также называется несколько конкретных структур данных , применяющихся при реализации абстрактных списков, особенно связных списков .
При помощи нотации метода Ч. Хоара определение списка можно записать следующим образом:
Первая строка данного определения обозначает, что список элементов типа (говорят: «список над ») представляет собой размеченное объединение пустого списка и декартова произведения атома типа со списком над . Для создания списков используются два конструктора (вторая строка определения), первый из которых создаёт пустой список, а второй — непустой соответственно. Вполне понятно, что второй конструктор получает на вход в качестве параметров некоторый атом и список, а возвращает список, первым элементом которого является исходный атом, а остальными — элементы исходного списка. То есть получается префиксация атома к списку, с чем и связано такое наименование конструктора. Пустой список не является атомом, а потому не может префиксироваться. С другой стороны, пустой список является нулевым элементом для конструирования списков, поэтому любой список содержит в самом своём конце пустой список — с него начинается конструирование.
Третья строка определяет для списка, то есть операции для доступа к элементам внутри списка. Селектор получает на вход список и возвращает первый элемент этого списка, то есть типом результата является тип . Этот селектор не может получить на вход пустой список — в этом случае результат операции неопределён. Селектор возвращает список, полученный из входного в результате отсечения его головы (первого элемента). Этот селектор также не может принимать на вход пустой список, так как в этом случае результат операции неопределён. При помощи этих двух операций можно достать из списка любой элемент. Например, чтобы получить третий элемент списка (если он имеется), необходимо последовательно два раза применить селектор , после чего применить селектор . Другими словами, для получения элемента списка, который находится на позиции (начиная с для первого элемента, как это принято в программировании), необходимо раз применить селектор , после чего применить селектор .
Четвёртая строка определения описывает предикаты для списка, то есть функции, возвращающие булевское значение в зависимости от некоторых условий. Первый предикат возвращает значение в случае, если заданный список пуст. Второй предикат действует наоборот. Наконец, пятая строка описывает части списка, которые, как уже сказано, представляют собой пустой и непустой списки.
У определённой таким образом структуры данных имеются некоторые свойства:
Списки используются для хранения наборов однотипных элементов. Такие элементы могут быть отсортированы для использования в функциях поиска или функциях для быстрой вставки новых элементов в список.
Списки в функциональных языках являются фундаментальной структурой. Большинство функциональных языков имеет встроенные средства для работы со списками вроде получения длины списка, головы (первый элемент списка), хвоста (часть списка, идущая за первым элементом), применения функции к каждому элементу списка ( Map ), свертки списка и пр.