Структуры данных и проектирование программ — В качестве фундаментальных средств разработки программ рассматриваются такие вопросы, как структурное решение задач, абстракция данных, принципы программной инженерии и сравнительный анализ алгоритмов. Дано полное освещение большинства модулей знаний, касающихся структур данных и алгоритмов. Большая часть глав начинается основной темой и сопровождается примерами, приложениями и практическими исследованиями. Это учебное пособие дает основательные знания, которые позволяют студентам по ходу своей дальнейшей работы использовать ее также в качестве справочного пособия.
Название: Структуры данных и проектирование программ Автор: Круз Р. Л. Издательство: Лаборатория знаний Год: 2021 Страниц: 768 Формат: PDF Размер: 16,84 МБ ISBN: 978-5-9963-1308-2 Качество: отличное Язык: русский
Содержание:
Предисловие Краткий обзор Изменения в третьем издании Структура курса Разработка книги Благодарности Глава 1. Принципы программирования 1.1. Введение 1.2. Игра «Жизнь» 1.2.1. Правила игры «Жизнь» 1.2.2. Примеры 1.2.3. Решение 1.2.4. Life: главная программа 1.3. Стиль программирования 1.3.1. Имена 1.3.2. Документация и форматы 1.3.3. Детализация программы и модульность 1.4. Кодирование, тестирование и дальнейшая детализация 1.4.1. Заглушки 1.4.2. Подсчет соседей 1.4.3. Ввод и вывод 1.4.4. Драйверы 1.4.5. Трассировка программы 1.4.6. Принципы тестирования программы Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Pascal Программистские принципы Игра «Жизнь» Глава 2. Введение в программную инженерию 2.1. Поддержка программ 2.1.1. Обзор программы Life 2.1.2. Новый старт и новый метод для программы Life 2.2. Разработка алгоритма: второй вариант программы Life 2.2.1. Списки: спецификации для структуры данных 2.2.2. Программа Main 2.2.3. Сокрытие информации 2.2.4. Детализация: разработка подпрограмм 2.2.5. Верификация и алгоритмы 2.3. Кодирование 2.3.1. Пакет обработки списков 2.3.2. Обработка ошибок 2.3.3. Демонстрация и тестирование 2.4. Кодирование процедур программы Life 2.5. Анализ и сравнение программ 2.6. Заключение и предварительный просмотр 2.6.1. Игра «Жизнь» 2.6.2. Разработка программы 2.6.3. Pascal Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 3. Стеки и рекурсия 3.1. Стеки 3.1.1. Введение 3.1.2. Первый пример: реверсирование строки 3.1.3. Сокрытие информации 3.1.4. Спецификации для стека 3.1.5. Реализация стеков 3.1.6. Связные стеки 3.2. Введение в рекурсию 3.2.1. Кадры стека для подпрограмм 3.2.2. Дерево вызовов подпрограмм 3.2.3. Факториалы: рекурсивное определение 3.2.4. Метод разбиения: башни Ханоя 3.3. Принципы рекурсии 3.3.1. Разработка рекурсивных алгоритмов 3.3.2. Как работает рекурсия 3.3.3. Хвостовая рекурсия 3.3.4. Когда не следует использовать рекурсию 3.3.5. Рекомендации и заключения Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 4. Примеры рекурсии 4.1. Алгоритмы с отходом: откладывание работы 4.1.1. Решение задачи о восьми ферзях 4.1.2. Пример: четыре ферзя 4.1.3. Алгоритм с отходом 4.1.4. Детализация: выбор структур данных 4.1.5. Анализ алгоритма с отходом 4.2. Древовидные программы: прогнозирование в играх 4.2.1. Деревья игр 4.2.2. Метод минимакса 4.2.3. Разработка алгоритма 4.2.4. Детализация 4.3. Компиляция методом рекурсивного спуска 4.3.1. Главная программа 4.3.2. Объявления типов 4.3.3. Синтаксический анализ предложений 4.3.4. Синтаксический анализатор предложений языка Pascal Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 5. Очереди 5.1. Определения 5.2. Реализация очередей 5.3. Кольцевые очереди в языке Pascal 5.4. Приложения очередей: Моделирование 5.4.1. Введение 5.4.2. Моделирование работы аэропорта 5.4.3. Случайные числа 5.4.4. Главная программа 5.4.5. Шаги моделирования 5.4.6. Пример результатов 5.5. Связные очереди 5.6. Приложения: полиномиальная арифметика 5.6.1. Цель проекта 5.6.2. Главная программа 5.6.3. Структуры данных и их реализация 5.6.4. Чтение и вывод полиномов 5.6.5. Сложение полиномов 5.6.6. Завершение проекта 5.7. Абстрактные типы данных и их реализации 5.7.1. Введение 5.7.2. Общие определения 5.7.3. Детализация спецификации данных Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 6. Списки 6.1. Спецификации списков 6.2. Реализация списков 6.2.1. Непрерывная реализация 6.2.2. Реализация простого связывания 6.2.3. Вариация: сохранение текущей позиции 6.2.4. Дважды связные списки 6.2.5. Сравнение реализаций 6.3. Цепочки символов 6.3.1. Операции над цепочками символов 6.3.2. Реализация цепочек символов 6.4. Приложение: текстовый редактор 6.4.1. Спецификации 6.4.2. Реализация 6.5. Связные списки в массивах 6.6. Генерирование перестановок Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 7. Поиск 7.1. Введение и обозначения 7.2. Последовательный поиск 7.3. Гардеробы: проект 7.3.1. Введение и спецификации 7.3.2. Демонстрационная и тестирующая программы 7.4. Двоичный поиск 7.4.1. Разработка алгоритма 7.4.2. Вариант с забыванием 7.4.3. Распознавание равенства 7.5. Деревья сравнений 7.5.1. Анализ для n= 7.5.2. Обобщение 7.5.3. Методы сравнения 7.5.4. Общее отношение 7.6. Нижние границы 7.7. Асимптотика 7.7.1. Введение 7.7.2. О большое 7.7.3. Неточность определения O большого 7.7.4. Порядки распространенных функций Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 8. Сортировка 8.1. Введение и обозначения 8.2. Сортировка включением 8.2.1. Упорядоченные списки 8.2.2. Сортировка методом включения 8.2.3. Связный вариант 8.2.4. Анализ 8.3. Сортировка методом выбора 8.3.1. Алгоритм 8.3.2. Непрерывная реализация 8.3.3. Анализ 8.3.4. Сравнения 8.4. Упорядочение методом Шелла 8.5. Нижние границы 8.6. Сортировка методом разбиения 8.6.1. Базовые идеи 8.6.2. Пример 8.7. Сортировка слиянием для связных списков 8.7.1. Процедуры 8.7.2. Анализ метода сортировки слиянием 8.8. Метод быстрой сортировки для непрерывных списков 8.8.1. Главная процедура 8.8.2. Разделение списка 8.8.3. Анализ метода быстрой сортировки 8.8.4. Анализ метода быстрой сортировки для среднего случая 8.8.5. Сравнение с методом слияния 8.9. Пирамиды и пирамидальная сортировка 8.9.1. Двухвариантные деревья как списки 8.9.2. Пирамидальная сортировка 8.9.3. Анализ пирамидальной сортировки 8.9.4. Очереди с приоритетами 8.10. Обзор: сравнение методов Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 9. Таблицы и извлечение информации 9.1. Введение: переход через барьер lgn 9.2. Прямоугольные массивы 9.3. Таблицы различных форм 9.3.1. Треугольные таблицы 9.3.2. Рваные таблицы 9.3.3. Инвертированные таблицы 9.4. Таблицы: новый абстрактный тип данных 9.5. Приложение: поразрядная сортировка 9.5.1. Идея метода 9.5.2. Реализация 9.5.3. Анализ 9.6. Хеширование 9.6.1. Разреженные таблицы 9.6.2. Выбор хеш-функции 9.6.3. Разрешение конфликтов с помощью открытой адресации 9.6.4. Разрешение столкновений посредством связных цепочек 9.7. Анализ хеширования 9.8. Заключение: сравнение методов 9.9. Приложение: снова игра «Жизнь» 9.9.1. Выбор алгоритма 9.9.2. Спецификация структур данных 9.9.3. Главная программа 9.9.4. Процедуры Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 10. Двоичные деревья 10.1. Двоичные деревья 10.1.1. Определения 10.1.2. Просмотр двоичных деревьев 10.1.3. Связная реализация двоичных деревьев 10.2. Деревья двоичного поиска 10.2.1. Упорядоченные списки и реализации 10.2.2. Поиск по дереву 10.2.3. Включение в дерево двоичного поиска 10.2.4. Древовидная сортировка 10.2.5. Удаление из дерева двоичного поиска 10.3. Построение дерева двоичного поиска 10.3.1. Начинаем 10.3.2. Объявления и главная процедура 10.3.3. Включение узла 10.3.4. Завершение задачи 10.3.5. Оценка 10.3.6. Случайные деревья поиска и оптимизация 10.4. Балансирование по высоте: AVL-деревья 10.4.1. Определение 10.4.2. Включение узла 10.4.3. Удаление узла 10.4.4. Высота AVL-дерева 10.5. Скошенные деревья: самонастраивающиеся структуры данных 10.5.1. Введение 10.5.2. Шаги скашивания дерева 10.5.3. Алгоритм скашивания 10.5.4. Амортизационный анализ алгоритмов: введение 10.5.5. Амортизационный анализ скашивания Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 11. Многовариантные деревья 11.1. Сады, деревья и двоичные деревья 11.1.1. Классификация видов 11.1.2. Упорядоченные деревья 11.1.3. Леса и сады 11.1.4. Формальное соответствие 11.1.5. Повороты 11.1.6. Резюме 11.2. Деревья лексикографического поиска: трай-деревья 11.2.1. Трай-деревья 11.2.2. Поиск ключа 11.2.3. Алгоритм на языке Pascal 11.2.4. Включение в трай-дерево 11.2.5. Удаление из трай-дерева 11.2.6. Оценка трай-деревьев 11.3. Внешний поиск: B-деревья 11.3.1. Время доступа 11.3.2. Многовариантные деревья поиска 11.3.3. Сбалансированные многовариантные деревья 11.3.4. Включение в B-дерево 11.3.5. Алгоритмы на языке Pascal: поиск и включение 11.3.6. Удаление из B-дерева 11.4. Красно-черные деревья 11.4.1. Введение 11.4.2. Определения и анализ 11.4.3. Включение 11.4.4. Включение на языке Pascal Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 12. Графы 12.1. Математические основы 12.1.1. Определения и примеры 12.1.2. Неориентированные графы 12.1.3. Ориентированные графы 12.2. Компьютерное представление 12.3. Просмотр графа 12.3.1. Методы 12.3.2. Алгоритм просмотра в глубину 12.3.3. Алгоритм просмотра в ширину 12.4. Топологическая сортировка 12.4.1. Постановка задачи 12.4.2. Алгоритм упорядочения в глубину 12.4.3. Алгоритм упорядочения в ширину 12.5. Алгоритм экономного продвижения: кратчайшие маршруты 12.6. Графы как структуры данных Подсказки и ловушки Обзорные вопросы Литература для дальнейшего изучения Глава 13. Конкретный пример: польская нотация 13.1. Постановка задачи 13.1.1. Формула корней квадратного уравнения 13.2. Идея 13.2.1. Дерево выражения 13.2.2. Польская нотация 13.2.3. Метод для языка Pascal 13.3. Оценка выражений в польской нотации 13.3.1. Оценка выражений в префиксной форме 13.3.2. Соглашения языка Pascal 13.3.3. Pascal-процедура для префиксной оценки 13.3.4. Оценка постфиксных выражений 13.3.5. Доказательство правильности программы: подсчет эле ментов в стеке 13.3.6. Рекурсивная оценка постфиксных выражений 13.4. Преобразование из инфиксной формы в польскую 13.5. Интерактивная программа оценки выражений 13.5.1. Общая структура 13.5.2. Представление данных 13.5.3. Инициализация и вспомогательные задачи 13.5.4. Преобразование выражения 13.5.5. Оценка выражения 13.5.6. Графическое отображение выражения Литература для дальнейшего изучения Приложение A. Математические методы A.1. Суммы степеней целых чисел A.2. Логарифмы A.2.1. Определение логарифмов A.2.2. Простые свойства A.2.3. Выбор основания A.2.4. Натуральные логарифмы A.2.5. Обозначения A.2.6. Изменение основания логарифмов A.2.7. Логарифмические графики A.2.8. Гармонические числа A.3. Перестановки, сочетания, факториалы A.3.1. Перестановки A.3.2. Сочетания A.3.3. Факториалы A.4. Числа Фибоначчи A.5. Числа Каталана A.5.1. Основной результат A.5.2. Доказательство посредством однозначного соответствия A.5.3. История вопроса A.5.4. Численные результаты Литература для дальнейшего изучения Приложение B. Случайные числа B.1. Введение B.2. Метод B.3. Разработка программы Литература для дальнейшего изучения Приложение С. Модули, включаемые файлы и утилиты C.1. Модули Turbo Pascal C.1.1. Введение C.1.2. Синтаксис модулей C.2. Включаемые файлы C.2.1. Замена модулей включаемыми файлами C.2.2. Родовые средства C.3. Модули, используемые в тексте C.3.1. Структуры данных C.3.2. Модуль утилит Utility C.3.3. Модуль анализа процессорного времени C.3.4. Модуль для обслуживания файлов C.3.5. Модуль случайных чисел C.4. Программы поиска и сортировки C.4.1. Демонстрационная программа C.4.2. Создание файлов данных для тестирования программ Приложение D. Свойства языка Pascal D.1. Записи в языке Pascal D.2. Процедуры D.2.1. Процедуры в качестве параметров D.2.2. Упреждающие объявления D.3. Указатели и связные списки D.3.1. Введение и обзор D.3.2. Указатели и динамическая память в языке Pascal D.3.3. Основы связных списков D.3.4. Связная реализация простых списков D.3.5. Советы для программистов D.4. Синтаксические диаграммы D.5. Общие правила D.5.1. Идентификаторы D.5.2. Правила использования пробелов D.5.3. Указания по формату программы D.5.4. Пунктуация D.5.5. Альтернативные знаки D.6. Стандартные объявления D.6.1. Константы D.6.2. Типы D.6.3. Переменные D.6.4. Процедуры D.6.5. Функции D.7. Операторы Предметный указатель