Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
312.doc
Скачиваний:
7
Добавлен:
30.04.2022
Размер:
2.14 Mб
Скачать

ФГБОУВПО «Воронежский государственный

технический университет»

Г.А. Кащенко Д.О. Карпеев

МЕТОДЫ ПРОГРАММИРОВАНИЯ

Утверждено Редакционно-издательским советом университета в качестве учебного пособия

Воронеж 2011

УДК 681.3.07

Кащенко Г.А. Методы программирования: учеб. пособие / Г.А. Кащенко, Д.О. Карпеев. Воронеж: ФГБОУВПО «Воронежский государственный технический университет», Воронеж, 2011. 170 с.

В учебном пособии по дисциплинам «Методы программирования» и «Средства и методы программирования» рассматриваются распространенные в практике программирования структуры данных, а также наиболее распространенные алгоритмы сортировки и поиска, рациональные по затратам памяти и дискового пространства. Излагаемый материал содержит оттестированные программы, реализованные на языках С++ и в системе программирования Delphi, которые используются как части создаваемых студентами более сложных программ.

Издание соответствует требованиям государственного образовательного стандарта высшего профессионального образования по направлению 090100 «Информационная безопасность», специальности 090106 "Информационная безопасность автоматизированных систем", дисциплинам «Методы программирования», «Средства и методы программирования».

Предназначено студентам очной формы обучения.

Учебное пособие подготовлено в электронном виде в текстовом редакторе MS Word 2007 и содержится в файле КащенкоМП.doc.

Ил. 23. Библиогр.: 14 назв.

Рецензенты: ОАО «Концерн «Созвездие»

(канд. техн. наук, доц. Р.В. Семенов);

канд. техн. наук, доц. Г.А. Остапенко

 Кащенко Г.А., 2011

 Оформление. ФГБОУВПО «Воронежский государственный технический университет», 2011

Введение

Главной целью настоящего пособия является изложение основных приемов и методов конструирования эффективных программ. Эффективность, наглядность и сложность программ существенно зависит от используемых в ней структур данных. В пособии представлены наиболее важные структуры данных и показано, при каких условиях их использование является наиболее целесообразным. Приведены реальные программы и алгоритмы обработки следующих структур данных: линейных списков, матриц и многомерных массивов, графов.

Учебное пособие ориентировано на типовую программу по дисциплинам «Методы программирования» и «Средства и методы программирования». Для изучения материала пособия необходимо знание языков программирования Pascal и С++. Кроме того также предполагается, что у студентов имеются определенные навыки практической работы на ПЭВМ по составлению и отладке небольших программ на одном из указанных выше языков программирования.

1. Оценки сложности алгоритмов

1.1. Определение понятия алгоритм

Решение задачи с помощью ЭВМ – это процесс автоматического преобразования исходной информации (исходных данных) в искомый результат в соответствии с заданной последовательностью действий, называемой алгоритмом.

Алгоритм – одно из основных понятий математики, которое невозможно строго определить, а можно лишь пояснить с помощью других слов. Можно сказать, что алгоритм – это точное предписание, которое задает вычислительный процесс, начинающийся из некоторой совокупности возможных для этого алгоритма исходных данных и направленный на получение полностью определяемого этими исходными данными результата.

Алгоритмы должны обладать следующими свойствами:

- конечность – работа алгоритма должна заканчиваться за конечное число шагов, хотя некоторые из шагов могут повторятся многократно.

- определенность (детерминированность) – все предписания алгоритма должны иметь однозначную трактовку и должны быть понятны исполнителю алгоритма, т.е. каждый шаг алгоритма должен быть однозначным, недвусмысленным, при одних и тех же исходных данных должны быть получены одни и те же результаты. При рассмотрении сложности алгоритмов термину «детерминированность» придают несколько иную, расширенную трактовку.

- массовость – решение целой группы задач, отличающихся исходными данными. Иногда при решении уникальной задачи это свойство может игнорироваться. Различаются массовые и индивидуальные задачи. Индивидуальная задача получается из массовой, если зафиксированы некоторые исходные данные. Алгоритм решает некоторую массовую задаче, если он решает любую индивидуальную задачу этой массовой задачи.

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

- эффективность – все шаги алгоритма должны быть такими, чтобы они выполнялись за конечное время, а общее время работы должно лежать в допустимых для решения этой задачи пределах.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]