Структура данных: различия между версиями

Материал из Поле цифровой дидактики
м (1 версия импортирована)
Строка 1: Строка 1:
[[Файл:binary tree.svg|thumb|192px|[[Бинарное дерево]], простой пример ветвящейся связной структуры данных.]]
'''Структура данных'''[[программная единица]], позволяющая хранить и обрабатывать однотипные и/или логически связанные [[данные (вычислительная техника)|данные]]. Для добавления, поиска, изменения и удаления данных структура данных предоставляет некоторый набор функций, составляющих её интерфейс.
'''Структура данных''' ({{lang-en|data structure}}) — [[программная единица]], позволяющая хранить и обрабатывать однотипные и/или логически связанные [[данные (вычислительная техника)|данные]]. Для добавления, поиска, изменения и удаления данных структура данных предоставляет некоторый набор функций, составляющих её интерфейс.


Термин «структура данных» может иметь несколько близких, но тем не менее различных значений{{sfn|Okasaki|1998|pp=3-4}}:
Термин «структура данных» может иметь несколько близких, но тем не менее различных значений:
* [[Абстрактный тип данных]];
* [[Абстрактный тип данных]];
* Реализация какого-либо абстрактного типа данных;
* Реализация какого-либо абстрактного типа данных;
Строка 14: Строка 13:
При разработке программного обеспечения сложность реализации и качество работы программ существенно зависят от правильного выбора структур данных. Это понимание дало начало формальным методам разработки и языкам программирования, в которых именно структуры данных, а не алгоритмы, ставятся во главу архитектуры программного средства. Большая часть таких языков обладает определённым типом [[Модульность (программирование)|модульности]], позволяющим структурам данных безопасно [[повторное использование кода|переиспользоваться]] в различных приложениях. [[Объектно-ориентированный язык программирования|Объектно-ориентированные языки]], такие как [[Java]], [[C Sharp|C#]] и [[C++]], являются примерами такого подхода.
При разработке программного обеспечения сложность реализации и качество работы программ существенно зависят от правильного выбора структур данных. Это понимание дало начало формальным методам разработки и языкам программирования, в которых именно структуры данных, а не алгоритмы, ставятся во главу архитектуры программного средства. Большая часть таких языков обладает определённым типом [[Модульность (программирование)|модульности]], позволяющим структурам данных безопасно [[повторное использование кода|переиспользоваться]] в различных приложениях. [[Объектно-ориентированный язык программирования|Объектно-ориентированные языки]], такие как [[Java]], [[C Sharp|C#]] и [[C++]], являются примерами такого подхода.


[[File:Python 3. The standard type hierarchy.png|thumb]]
https://upload.wikimedia.org/wikipedia/commons/1/10/Python_3._The_standard_type_hierarchy.png
 
Многие классические структуры данных представлены в стандартных библиотеках языков программирования или непосредственно встроены в языки программирования. Например, структура данных хеш-таблица встроена в языки программирования [[Lua]], [[Perl]], [[Python]], [[Ruby]], [[Tcl]] и др. Широко используется [[стандартная библиотека шаблонов]] (STL) языка C++.
Многие классические структуры данных представлены в стандартных библиотеках языков программирования или непосредственно встроены в языки программирования. Например, структура данных хеш-таблица встроена в языки программирования [[Lua]], [[Perl]], [[Python]], [[Ruby]], [[Tcl]] и др. Широко используется [[стандартная библиотека шаблонов]] (STL) языка C++.


Строка 20: Строка 20:


== Сравнение структур данных в функциональном и императивном программировании ==
== Сравнение структур данных в функциональном и императивном программировании ==
Проектировать структуры данных для функциональных языков более сложно, чем для императивных, как минимум по двум причинам{{sfn|Okasaki|1998|pp=3-4}}:
Проектировать структуры данных для функциональных языков более сложно, чем для императивных, как минимум по двум причинам:
# Почти все структуры данных интенсивно используют [[присваивание]], которое в чисто функциональном стиле не используется;
# Почти все структуры данных интенсивно используют [[присваивание]], которое в чисто функциональном стиле не используется;
# Функциональные структуры данных являются более гибкими, и поэтому там, где в императивном программировании старая версия теряется, просто заменяясь новой, в функциональном она автоматически продолжает существовать. Другими словами, в императивном программировании (если не принять особых мер, которые могут серьёзно усложнить программу) структуры данных являются '''''эфемерными''''' ({{lang-en|ephemeral}}), а в функциональных программах они как правило '''''постоянные''''' ({{lang-en|persistent}}).
# Функциональные структуры данных являются более гибкими, и поэтому там, где в императивном программировании старая версия теряется, просто заменяясь новой, в функциональном она автоматически продолжает существовать. Другими словами, в императивном программировании (если не принять особых мер, которые могут серьёзно усложнить программу) структуры данных являются '''''эфемерными''''', а в функциональных программах они как правило '''''постоянные'''''.
 
== Примечания ==
{{примечания}}
 
== Литература ==
* {{книга
|автор = Альфред В. Ахо, [[Джон Хопкрофт]], Джеффри Д. Ульман.
|заглавие = Структуры данных и алгоритмы
|оригинал = Data Structures and Algorithms
|место = М. |издательство = [[Вильямс (издательство)|Вильямс]]
|год = 2000
|страниц = 384
|isbn = 0-201-00023-7
|ref=Ахо, Ульман
}}
* {{книга
|автор = Майкл Мейн, Уолтер Савитч.
|заглавие = Структуры данных и другие объекты в C++
|оригинал = Data Structures and Other Objects Using C++
|издание = 2-е изд
|место = М. |издательство = [[Вильямс (издательство)|Вильямс]]
|год = 2002
|страниц = 832
|isbn = 0-201-70297-5
|ref = Мейн, Савитч
}}
* {{книга
|автор = Chris Okasaki
|заглавие = Purely Functional Data Structures
|издательство = Cambridge University Press
|год = 1998
|страниц = 232
|isbn = 978-0521663502
|ref=Okasaki
}}
 
== Ссылки ==
* [http://algolist.manual.ru/ds/ Структуры данных и хеширование]
{{rq|refless|topic=ИТ}}


{{Структуры данных}}
{{Типы данных}}


__NOTOC__


[[Категория:Структуры данных| ]]
[[Категория:Структуры данных| ]]
[[Категория:Вычислительная техника]]

Версия 10:40, 19 октября 2022

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

Термин «структура данных» может иметь несколько близких, но тем не менее различных значений:

  • Абстрактный тип данных;
  • Реализация какого-либо абстрактного типа данных;
  • Экземпляр типа данных, например, конкретный список;
  • В контексте функционального программирования — уникальная единица (Шаблон:Lang-en), сохраняющаяся при изменениях. О ней неформально говорят как об одной структуре данных, несмотря на возможное наличие различных версий.

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

Различные виды структур данных подходят для различных приложений; некоторые из них имеют узкую специализацию для определённых задач. Например, B-деревья обычно подходят для создания баз данных, в то время как хеш-таблицы используются повсеместно для создания различного рода словарей, например, для отображения доменных имён в интернет-адресах компьютеров.

При разработке программного обеспечения сложность реализации и качество работы программ существенно зависят от правильного выбора структур данных. Это понимание дало начало формальным методам разработки и языкам программирования, в которых именно структуры данных, а не алгоритмы, ставятся во главу архитектуры программного средства. Большая часть таких языков обладает определённым типом модульности, позволяющим структурам данных безопасно переиспользоваться в различных приложениях. Объектно-ориентированные языки, такие как Java, C# и C++, являются примерами такого подхода.

Python_3._The_standard_type_hierarchy.png

Многие классические структуры данных представлены в стандартных библиотеках языков программирования или непосредственно встроены в языки программирования. Например, структура данных хеш-таблица встроена в языки программирования Lua, Perl, Python, Ruby, Tcl и др. Широко используется стандартная библиотека шаблонов (STL) языка C++.

Фундаментальными строительными блоками для большей части структур данных являются массивы, записи (struct в Си и record в Паскале), размеченные объединения (union в Си) и ссылки. Например, двусвязный список может быть построен с помощью записей и ссылок, где каждая запись (узел) будет хранить данные и ссылки на «левый» и «правый» узлы.

Сравнение структур данных в функциональном и императивном программировании

Проектировать структуры данных для функциональных языков более сложно, чем для императивных, как минимум по двум причинам:

  1. Почти все структуры данных интенсивно используют присваивание, которое в чисто функциональном стиле не используется;
  2. Функциональные структуры данных являются более гибкими, и поэтому там, где в императивном программировании старая версия теряется, просто заменяясь новой, в функциональном она автоматически продолжает существовать. Другими словами, в императивном программировании (если не принять особых мер, которые могут серьёзно усложнить программу) структуры данных являются эфемерными, а в функциональных программах они как правило постоянные.