Программа дисциплины «Информатика и программирование»

Вид материалаПрограмма дисциплины

Содержание


Дополнительные материалы для подготовки к контрольнойпо теме «Оценка сложности алгоритмов» Оценка алгоритмов, содержащих ветвлен
Средняя сложность программы
Подобный материал:
1   2   3   4   5   6   7

Дополнительные материалы для подготовки к контрольной
по теме «Оценка сложности алгоритмов»

Оценка алгоритмов, содержащих ветвления


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

Для определения средней сложности необходимо оценить частоты выбора ветвей.

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

Средняя сложность программы (ее алгоритма) вычисляется как сумма произведений весов ветвей на их частоты.

Если в программе имеются вложенные ветвления, то можно предложить метод оценки, основанный на оценке частоты, с которой встречаются определенные комбинации входных данных. Рассмотрим его.

Пусть управляющий граф программы содержит ветвления, где выбор ветвей определяется условиями C1, C2, C3, …, Cn. Вид управляющего графа представлен на рис. 1.



Рис. 1. Пример управляющего графа с ветвлениями

Проверка условия C1 выполняется всегда, таким образом оно разбивает все ветви на две группы: для первой условие истинно, для второй ­– ложно. Условие C2 разбивает группу ветвей, для которых условие C1 истинно, еще на две группы, для которых истинны условия (C1 and C2) и (C1 and not C2) соответственно. Условие C3 также разбивает группу ветвей, для которых условие C1 ложно, еще на две группы, удовлетворяющих условиям (not C1 and C3) и (not C1 and not C3) соответственно. Для следующих ветвлений (до Cn) этот процесс «разбиения» ветвей на группы можно было бы продолжить.

Выбор ветвей определяется комбинацией входных данных D. Множество комбинаций исходных данных D также можно разбить на две части D1 и D2 (два подмножества), порождаемые условием C1. В свою очередь D1 делится на D3 и D5, а D2 разбивается на D5 и D6 (рис. 2). Каждая область (подмножество D), которая не разбивается больше ни на какие другие более мелкие части, соответствует ветви в управляющем графе (ветви пересекаются в начальной части графа ­– для общих условий, определяющих их выбор). Все такие подмножества комбинаций входных данных (областей на рисунке) обозначим di. В том случае, когда все комбинации исходных данных являются равновероятными, частоту исполнения i й ветви можно оценить как отношение мощности подмножества di к мощности всего множества D: pi = | di | / | D |. Если имеются оценки li веса (сложности) i й ветви, то сложность такого алгоритма  с ветвлениями можно оценить величиной

,

где k – количество всех ветвей.



Рис. 2. Разбиение множества комбинаций входных данных, соответствующее
примеру управляющего графа с ветвлениями (рис. 1)


Пример. Пусть алгоритм с ветвлением имеет вид

read(X);

if X < 0.5 then Y := (X + 0.5) * 2

else if X < 0.75 then Y := X * 2 + 0.5 + X**2 + X**3

else := X

Допустим, что значение переменной X может принадлежать диапазону [0.00, 1.00], причем ввод любого значения из указанного диапазона равновероятен. Тогда вероятность того, что значение X  [0.00, 0.50), примерно равна вероятности того, что X  [0.50, 1.00]. В приведенном примере вероятность выбора ветви Y := (X + 0.5) * 2 равна 0.5. При невыполнении условия X < 0.5 выбор ветви определяется проверкой условия X < 0.75. Причем ветви выбираются также равновероятно, поэтому частота выбора каждой равна примерно 0.25. Разбиение всего множества комбинаций (в данном случае каждая комбинация определяется только значением переменной X) показано на рис. 3.



Рис. 3. Геометрическая вероятность ввода значений переменной, определяемая
длинами отрезков числовой прямой (значения равновероятны)


Таким образом, при выполнении программы возможен выбор трех ветвей:

1) ветви Y := (X + 0.5) * 2, соответствующей условию X < 0.5, вес (сложность) которой составляет 5 (ввод, проверка условия, вычисление выражения (2 операции) и присваивание), а вероятность выбора ­– 0.5;

2) ветви Y := X * 2 + 0.5 + X**3, соответствующей условию not(X < 0.5) and (X < 0.75), вес (сложность) которой составляет 10 (ввод, проверка условия X < 0.5, проверка условия X < 0.75, вычисление выражения (6 операций) и присваивание), а вероятность выбора ­составляем 0.25;

3) ветви Y := X, соответствующей условию not(X < 0.5) and not(X < 0.75), вес (сложность) которой составляет 4 (ввод, проверка условия X < 0.5, проверка условия X < 0.75, и присваивание), а вероятность ее выбора ­– примерно 0.25.

Средняя сложность алгоритма составляет

TAvrg = 0,5  5 + 0,25  10 + 0,25  4 = 2,5 + 2,5 + 1 = 6.

Определите максимальную и минимальную сложность приведенного алгоритма.