МИНИСТЕРСТВО НАУКИ И ОБРАЗОВАНИЯ УКРАИНЫ
Одесский национальный политехнический университет
Институт компьютерных систем
Кафедра "Компьютерные интеллектуальные системы и сети"
Курсовая работа
Динамические структуры данных
2004
Аннотация Целью данной работы служит разработка эффективных алгоритмов на динамических структурах данных.
Главной особенностью динамических структур является возможность изменения их структуры и размера в процессе работы программы. Это существенно повышает гибкость программы, размер структуры ограничивается только размером памяти машины. Однако такая гибкость обходится несколько большими затратами памяти на хранение самой структуры и её обработку, поскольку дополнительную память требуют указатели.
Алгоритмы работы с этими структурами очень сильно зависят от вида самой структуры.
В данной работе представлены алгоритмы работы со стеком. Также здесь представлена инструкция пользователя по данной программе.
Содержание
Аннотация
1. Теоретические сведения
1.1 Описание структуры данных "стек"
2. Разработка
2.1 Процедура добавления элемента
2.2 Процедура удаления элемента
2.3 Процедура очистки памяти
2.4 Распечатка содержимого
3. Инструкция пользователя
4. Код программы
5. Контрольный пример
Заключение
Перечень используемой литературы
Приложения
1. Теоретические сведения В этом разделе мы ознакомимся с динамическими структурами данных и собственно стеком.
Достоинства динамических структур данных
Динамические структуры данных по определению характеризуются отсутствием физической смежности элементов структуры памяти непостоянством и непредсказуемостью размера (числа элементов4) структуры в процессе её обработки. В этом разделе рассмотрены особенности динамических структур, определяемые их первым характерным свойством.
Поскольку элементы динамической структуры располагаются по непредсказуемым адресам памяти, адрес элемента такой структуры не может быть вычислен из адреса начального или предыдущего элемента. Для установления связи между элементами динамической структуры используются указатели, через которые устанавливаются явные связи между элементами. Такое представление данных в памяти называется связным.
Элемент динамической структуры состоит из двух полей:
информационного поля или поля данных, в котором содержатся те данные, ради которых и создается структура; в общем случае информационное поле само является интегрированной структурой-вектором, массивом, записью и т.п.;
поле связок, в котором содержатся один или несколько указателей, связывающий данный элемент с другими элементами структуры.
Когда связное представление данных используется для решения прикладной задачи, для конечного пользователя видимым делается только содержимое информационного поля, а поле связок используется только программистом-разработчиком.
Достоинства связного представления данных:
в возможности обеспечения значительной изменчивости структур;
размер структуры ограничивается только размером памяти машины;
при изменении логической последовательности элементов структуры требуется не перемещение данных в памяти, а только коррекция указателей.
Однако существуют и недостатки:
работа с указателями требует, как правило, более высокой квалификации от программиста;
на поля связок расходуется дополнительная память;
доступ к элементам связной структуры может быть менее эффективным по времени.
Применение динамических структур
Последний недостаток является наиболее серьёзным и именно им ограничивается применимость связного представления данных. ............