Автор работы: Пользователь скрыл имя, 18 Июня 2012 в 08:48, реферат
Теория алгоритмов, как наука, непосредственно связана с предметами математической логики и теории конечных автоматов. В Древней Греции Аристотель и его ученик Платон сформулировали основные правила логики, которые используются до нашего времени для доказательства правильности и решения логических задач.
Представление алгоритма в виде блок-схемы отличается высокой степенью наглядности. Блок-схема состоит из соединенных между собой стрелками (линиями потока информации) блоков различного вида, начертание которых регламентируется ГОСТ 19701-90. Применительно к рассматриваемой задаче блок-схема алгоритма выглядит:
Представление алгоритма с помощью структурограммы позволяет изображать схему передач управления не с помощью явного указания линий потоков информации, а посредством представления вложенности структур:
Запись алгоритма на конкретном языке программирования представляет собой текст программы, который текст должен быть откомпилирован, то есть, переведен на язык машинных команд, понятный компьютеру.
Program nod;
Var m, n: integer;
Begin
Writeln(‘Введите исходные числа m и n’); Read(m,n);
While m<>n do
If m>n Then m:=m-n Else n:=n-n;
Writeln(‘НОД равен’, m:3);
End.
1.5 Свойства алгоритмов.
1. Дискретность. Алгоритм определяет дискретный характер процесса решения задачи. Поэтому правило, порождающее непрерывный характер процесса решения задачи, не является алгоритмом.
Примеры:
«Уходя, гасите свет» - примитивный алгоритм.
«Правила
пользования междугородним
«Не курить» - непрерывный процесс, не являющийся алгоритмом.
2. Массовость. Алгоритм должен решать не одну конкретную задачу (ограниченное множество неизменных исходных данных), а серию однотипных задач. Т. е. множество различных исходных данных порождает различные результаты.
Хоты массовость является одним из свойств большинства алгоритмов, также ценность представляют алгоритмы, имеющие единственный вариант исходных данных.
Нужно считать, что для каждого алгоритма существует некоторый класс объектов, допустимых в качестве исходных данных.
Массовость алгоритма – это допустимость всех объектов соответствующего класса, а не допустимость какого-либо их количества.
3. Детерминированность. Реализация алгоритма является детерминированным (определенным) процессом. Всякий раз при запуске алгоритма с одинаковыми исходными данными должен получаться одинаковый результат, т. е. алгоритм может быть повторен сколько угодно раз.
4. Потенциальная осуществимость алгоритма. Говорят, что алгоритм применим к допустимому исходному данному, если с его помощью можно получить искомый результат. Иначе, хотя исходное данное и допустимо, но алгоритм к нему не применим.
Неприменимость
алгоритма к допустимому
Отвлекаясь
от реальной ограниченности времени
и ресурсов, необходимых для выполнения
алгоритма, требуют лишь того, чтобы
алгоритмический процесс
Пример1. Бесконечный цикл:
i=0
while i<= 10 do
k=k*2;
Пример 2. Последовательность вычислений:
1. b=2*a
2. b=b+1
3. c=b mod 3 a=6®d=6
4. d=a/c a=7®алгоритм не применим (ошибка деления на ноль).
Кроме потенциальной осуществимости алгоритма на практике требуется и реальная осуществимость.
5. Понятность. Алгоритм понятен для исполнителя, если он знает, как его выполнять (know how). Возникает вопрос: что именно должен знать исполнитель?
Свойство понятности можно истолковать как наличие алгоритма, определяющего процесс выполнения заданного алгоритма. В этом случае исполнителями могут быть любые объекты. Тогда исполнителю должен быть известен алгоритм (руководство к действию) для решения всех других алгоритмов, соответствующих исполнителю. Таким образом, возникает рекурсивное определение алгоритма, например, любая операционная система – это алгоритм алгоритмов.
6. Корректность. Алгоритм корректен, если выполняются три условия:
Если хоть одно из этих условий не выполняется, то алгоритм считается некорректным.
Вычислительная погрешность (машинная точность) возникает из-за ограниченной разрядной сетки ЭВМ и операций округления.
Обусловленность алгоритма показывает чувствительность результата работы алгоритма к малым, но неизбежным ошибкам вычислений.
Алгоритм хорошо обусловлен, если малые вычислительные погрешности приводят к малой относительной погрешности результата.
Для плохо обусловленного алгоритма .
Примечание 1. Если задача корректна и хорошо обусловлена, то плохо обусловленный алгоритм даёт неправильное решение и требует замены.
Примечание
2. Если исходная задача не корректна
и плохо обусловлена, то никакой хороший
алгоритм не даст правильного решения.
Пример3: Алгоритм деления двух чисел столбиком не корректен, если не задан критерий окончания вычислительного процесса.
Пример4: Рассмотрим задачу нахождения корней квадратного уравнения:
Пусть точное значение выходного данного x=5, а результат измерений и ввода в компьютер значений входных данных a,b,c содержит малую погрешность .
Тогда для точных значений входных данных существует единственный действительный корень (D=0), а погрешность входных данных приводит к появлению комплексных корней, не имеющих физического смысла при решении задачи.
Пример5: Вычислить значение интеграла
При
вычислениях допускать
Выполним интегрирование по частям и получим рекуррентную формулу
Будем проводить вычисления начиная со значения I0. Тогда на девятом шаге получим , что приводит в дальнейшем к росту погрешности и неправильному результату. Погрешность вычислений растёт со скоростью факториала.
Вывод: Алгоритм неустойчив при .
Однако, устойчивость алгоритма зависит от порядка вычислений. Так, если проводить вычисления в обратном порядке по формуле , начиная с конца, например, n=54, то на первом шаге ошибка будет велика порядка 0,05, но с каждым шагом она будет уменьшаться со скоростью факториала, что обеспечивает правильное решение в целом.
Пример 6: Вычислить значение функции .
А) при объявлении в программе переменной X : real вещественного типа, для её хранения в памяти компьютера отводится 6 байт, что позволяет хранить числа в диапазоне {10-38…1038}. Прямой порядок произведения чисел уже на первом шаге выдает ошибку переполнения в программе: .
Б) тоже самое возникает при обратном порядке перемножения чисел: .
В) Сгруппируем пары произведений чисел и обеспечим корректность алгоритма
Если алгоритм создан для решения определенной задачи (заданного набора исходных данных), то для любого исходного данного из этого набора должно формироваться правильное решение. Эмпирические алгоритмы, как правило, не корректны.
В этом смысле иногда используется более простое толкование свойства корректности. Считают, что алгоритм корректен, если его можно применить.
7. Эффективность. Данное свойство определяет быстродействие и связано с понятием вычислительной сложности алгоритма.
Эмпирические алгоритмы, как правило, не являются эффективными. Теоретические алгоритмы являются корректными и эффективными, но могут быть реально неосуществимы.
1.6
Классификация алгоритмов.
I. Т. к. алгоритм создается для решения задач одного класса, то вводят классификацию алгоритмов по типу решаемых задач:
II. По способу создания (источники) различают:
III. По критерию реализуемости различают:
IV. По критерию сложности различают:
1.7
Методы доказательства
корректности алгоритмов.
I. Корректность эмпирических алгоритмов обычно доказывается экспериментально. Такой алгоритм корректен, если он позволяет получить правильное решение для всего набора допустимых исходных данных.
II. Корректность теоретически обусловленных алгоритмов гарантируется формальным доказательством.
III. Корректность комбинационных алгоритмов, полученных на основе других ранее известных и заведомо корректных алгоритмов, определяется различными методами: