Алгоритмы и программы

Автор работы: Пользователь скрыл имя, 18 Июня 2012 в 08:48, реферат

Описание работы

Теория алгоритмов, как наука, непосредственно связана с предметами математической логики и теории конечных автоматов. В Древней Греции Аристотель и его ученик Платон сформулировали основные правила логики, которые используются до нашего времени для доказательства правильности и решения логических задач.

Файлы: 1 файл

Глава 1.doc

— 429.00 Кб (Скачать файл)

Представление алгоритма в виде блок-схемы отличается высокой степенью наглядности. Блок-схема состоит из соединенных между собой стрелками (линиями потока информации) блоков различного вида, начертание которых регламентируется ГОСТ 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. Результат работы алгоритма устойчив к вычислительной погрешности (свойство обусловленности).

    Если  хоть одно из этих условий не выполняется, то алгоритм считается некорректным.

    Вычислительная погрешность (машинная точность) возникает из-за ограниченной разрядной сетки ЭВМ и операций округления.

    Обусловленность алгоритма показывает чувствительность результата работы алгоритма  к малым, но неизбежным ошибкам вычислений.

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

    

    Для плохо обусловленного алгоритма .

Примечание 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. Т. к. алгоритм создается для решения задач одного класса, то вводят классификацию алгоритмов по типу решаемых задач:

    1. Табличные алгоритмы имеют в своей основе таблицу (поле исходных значений) и правила поиска решений.
    2. Численные алгоритмы задаются в виде формул и блок-схем. В их основе значительную роль играют арифметические операции (+,–,  /, *).
    3. Алгоритмы игр имеют в основе логические задачи.
    4. Комбинационные алгоритмы представляют собой совокупность алгоритмов других классов.
 

    II. По способу создания (источники) различают:

    1. Эмпирические алгоритмы – алгоритмы, полученные в ходе эксперимента или имитационного моделирования.
    2. Теоретически обусловленные алгоритмы – алгоритмы, возникшие из основных положения какой-либо теории.
    3. Эвристические алгоритмы – алгоритмы, основанные на личном опыте, таланте и изобретательности разработчика.
    4. Комбинационные алгоритмы – генерируются из уже известных алгоритмов.
 

    III. По критерию реализуемости различают:

    1. Простые алгоритмы – хорошо обусловленные алгоритмы.
    2. Трудно разрешимые алгоритмы – алгоритмы решения частных задач, обладающих большой сложностью и не являющихся эффективными.
    3. Нереализуемые алгоритмы.

    IV. По критерию сложности различают:

  1. Алгоритмы с логарифмической сложностью.
  2. Полиномиальные алгоритмы (класс P).
  3. Недетерминированные полиномиальные алгоритмы (класс NP), имеющие степенную или факториальную сложность.
 

    1.7 Методы доказательства корректности алгоритмов. 

    I. Корректность эмпирических алгоритмов обычно доказывается экспериментально. Такой алгоритм корректен, если он позволяет получить правильное решение для всего набора допустимых исходных данных.

    II. Корректность теоретически обусловленных алгоритмов гарантируется формальным доказательством.

    III. Корректность комбинационных алгоритмов, полученных на основе других ранее известных и заведомо корректных алгоритмов, определяется различными методами:

    1. Конструирование алгоритмов. Новый алгоритм получают комбинированием уже известных алгоритм как составных частей.
    2. Метод эквивалентных преобразований алгоритма. Два алгоритма считаются эквивалентными, если:
      • всякий вариант исходных данных, допустимый для одного алгоритма, также допустим и для другого;
      • применимость одного алгоритма к каким-либо исходным данным гарантирует, что и другой алгоритм тоже к ним применим;
      • результаты, даваемые как первым, так и вторым алгоритмами при одинаковых входных данных также одинаковы.

Информация о работе Алгоритмы и программы