1.1. Основные понятия теории алгоритмов
Алгоритм – это конечная совокупность точно сформулированных правил, определяющих эффективную процедуру решения любой задачи из некоторого класса задач.
Первоначально для записи алгоритмов использовались средства обычного языка. Поэтому изучение теории алгоритмов целесообразно начать именно со словесного описания алгоритмов.
……………………………… …………n
Пример 1. Необходимо описать процесс вычисления величины С= П Аi
i=1
Это может быть записано в виде следующей системы указаний:
1 Полагаем С=1 и переходим к следующему указанию.
2 Полагаем i=1 и переходим к следующему указанию.
3 Полагаем С=С*Аi и переходим к следующему указанию.
4 Проверяем, равно ли i числу N+1. Если i=N+1, вычисления прекращаем, иначе, увеличиваем i на 1 и переходим к указанию 3.
В этом простейшем алгоритме в качестве элементарных операций используются простейшие арифметические операции.
Алгоритмы, в соответствии с которыми решение поставленных задач сводится к арифметическим действиям, называются числовыми.
Пример 2.
Алгоритм нахождения минимального числа в массиве из n чисел A1, A2,…An.
При описании последовательности действий, аналогичной последовательности для примера 1, можно заметить, что основными элементарными операциями здесь являются операции сравнения, то есть логические операции,
Алгоритмы, в соответствии с которыми решение поставленных задач сводится к логическим действиям, называются логическими.
Примерами логических алгоритмов могут служить алгоритмы поиска минимального числа, пути в графе, пути в лабиринте и т.п.
В современной математике алгоритмами принято называть конструктивно заданные соответствия между словами в абстрактных алфавитах.
Абстрактным алфавитом называется любая конечная совокупность объектов, называемых буквами или символами данного алфавита.
Природа этих объектов нас совершенно не интересует. Символом абстрактного алфавита могут быть буквы, цифры, любые значения, рисунки и даже слова конкретного языка. Важно лишь, чтобы рассматриваемый алфавит был конечным.
Например, пусть задаются алфавиты A={ a, b, g} и B={ x, y },
Под словом или строкой алфавита будем понимать любую конечную упорядоченную последовательность символов.
Например, a, ab, bb, a b, …. или xy, yyy, xyxx…..
Число символов в слове называется длиной слова.
Наряду со словами положительной длины, состоящими не менее чем из одного символа, в ряде случаев целесообразно рассматривать также пустые слова, не содержащие ни одного символа.
При расширении алфавитов, то есть при включении в его состав новых символов, понятие слова не претерпит существенных изменений.
Так , например, в алфавите А={0,1,2,…,9} выражение 63+79 представляет собой два слова, соединенных знаком +, а в алфавите В={+,0,1,2,…,9} это будет одно слово.
Алфавитным оператором или алфавитным отображением называют всякое соответствие, сопоставляющее словам некоторого алфавита слова в том же самом алфавите или в каком-то другом фиксированном алфавите.
При этом первый алфавит называется входным, второй – выходным алфавитом данного оператора.
В случае совпадения входных и выходных алфавитов говорят, что алфавитный оператор задан в соответствующем алфавите.
Иначе говоря, алфавитный оператор – функция, задающая соответствие между словами входного алфавита и словами выходного алфавита.
Пусть нам заданы слова в алфавитах А и В и заданы соответствия между этими словами.
Если a – слово в алфавите А, а b – слово в алфавите В, то алфавитный оператор Г(a)=b перерабатывает входное слово a в выходное слово b,
где Г - алфавитное отображение.
Различают однозначные и многозначные алфавитные операторы (АО).
Под однозначным алфавитным оператором понимается такое алфавитное отображение, которое каждому входному слову ставит в соответствие не более одного выходного слова.
Например:
a1----------------------------------------------b2
a2----------------------------------------------b3
a3----------------------------------------------b1
Алфавитный оператор, не сопоставляющий данному входному слову ai никакого выходного слова bj (в том числе и пустого) не определен на этом слове.
Совокупность всех слов, на которых алфавитный оператор определен, называется его областью определения.
С каждым алфавитным оператором связывается интуитивное представление об его сложности. Наиболее простым является алфавитный оператор, осуществляющий посимвольное отображение. Посимвольное отображение состоит в том, что каждый символ S входного слова a заменяется символом выходного алфавита b.
Большое значение имеют, так называемые кодирующие отображения.
Под кодирующим отображением понимается соответствие, сопоставляющее каждому символу входного алфавита некоторую конечную последовательность символов выходного алфавита, называемую кодом.
Рассмотрим пример кодирующего отображения:
Пусть заданы два алфавита:
А={p,r,s,t} – входной алфавит;
B={aa,b,c,d,f,g,h,m,n,q} –выходной алфавит;
Отображения символов алфавита А символами алфавита В имеет вид:
R mn
S fgh
T abcd.
Пусть задано слово a=sstr, тогда Г(a)=fghfghabcdmn – код некоторого слова a в алфавите В.
Процесс, обратный кодированию, то есть замена в слове bj кодов алфавита В словами из алфавита А, называется декодированием и обозначается Г-1 (bj) = ai.
Например, для слова b =fghmnqdbfgh в алфавите В декодирование имеет вид: Г-1(b)=srps.
Если при кодировании слова ai получается некоторое слово bj , а декодирование дает исходное слово ai (Г(aI) = bj,, Г-1(bj) = ai.), то имеет место обратимость кодирования.
Условие обратимости кодирования есть не что иное, как условие взаимной однозначности соответствующего кодирующего отображения.
Рассмотрим еще один пример:
Пусть заданы алфавиты А = {a,b,c} и B = {a,b},а также отображения:
Г(a)=a, Г(b)= b, Г(c)= и слово aabca в алфавите А.
Тогда, Г(aabca)= aababa , а Г-1(aababa)= aababa или acca или aabca или acaba, т.е. обратимость отсутствует.
Для обратимости кодирования должны выполняться два следующих условия:
1) Коды разных символов должны быть различны;
2) Код любого символа алфавита А не может совпадать ни с одним из начальных отрезков слов других слов этого алфавита.
Следует отметить, что второе условие выполняется в том случае, если коды всех символов исходного алфавита А имеют одинаковую длину.
Кодирование, при котором все коды имеют одинаковую длину, называется нормальным.
Кодирование позволяет сводить изучение произвольных алфавитных отображений к алфавитным отображениям в некотором стандартном алфавите.
Наиболее часто в качестве такого алфавита выбирается двоичный алфавит С={0,1}.
Если n- число символов в алфавите А, а m- число символов в алфавите С, то всегда можно выбрать длину слова k так, чтобы удовлетворялось условие
mk>= n.
Поскольку число различных символов длины k в m-символьном алфавите равно mk, то все символы в алфавите А можно закодировать словами длины k в алфавите С так, чтобы коды различных букв были различны. Любое такое кодирование будет нормальным и порождает обратное кодирующее отображение слов в алфавите А в слова в алфавите С
Обозначим это отображение через Г(a)= c,
а обратное ему отношение Г-1(с)=a,
где a -слово в алфавите А,
с - слово в алфавите С.
Пусть ja – произвольный оператор в алфавите А такой, что ja = a1, а
yc – произвольный алфавитный оператор в алфавите С такой, что yc =с1.
Тогда отображение
yc = Г-1 (с), ja, Г(a1), (1)
получаемое в результате последовательного выполнения отображений
Г-1с, ja, Гa1 будет представлять собой некоторый оператор в стандартном алфавите С.
Назовем этот оператор yc алфавитным оператором в алфавите С сопряженным (при помощи кодирования Г(a1) и декодирования Г-1 (с )) с алфавитным оператором ja. Оператор ja однозначно восстанавливается по сопряженному оператору yc и соответствующим кодирующему Г(a) и декодирующему Г-1 (с) , отображениям ja=Г(a), yc , Г-1 (с1 ). (2)
Рассмотрим взаимосвязь сопряженных операторов на графе.
Г-1 (с) Г(a) Г-1 (с1 ) Г(a1 )
Применение формул (1) и (2) позволяет сводить произвольные алфавитные операторы к алфавитным операторам в стандартном алфавите.
Это соотношение справедливо и для случая, когда входной алфавит А, выходной алфавит В и стандартный алфавит С различны, т.е. для случая алфавитных операторов, у которых входные и выходные алфавиты различны:
Тогда,
yc =Г-1 (с), ja, Г(b)
ja=Г(a), yc , Г-1 (с1 )
Понятие алфавитного отображения является чрезвычайно общим.
К нему фактически сводятся или могут быть сведены любые процессы преобразования информации. И таким образом, к изучению алфавитиных отображений фактически сводится теория любых преобразований информации.
Для некоторых специальных видов информации, например, информации лексической, числовой применяется алфавитный способ задания в чистом виде. Преобразование этих видов информации сводится к алфавитным отображениям самым непосредственным образом: как входная , так и выходная информация в любом преобразователе в этом случае может быть представлена в виде слов, а преобразование информации сводится к установлению некоторого соответствия между словами.
Одной из характерных задач преобразования лексической информации является перевод текстов с одного языка на другой.
Качественный и грамотный перевод допускает возможность известных модификаций переводимого текста. Поэтому процесс перевода описывается не однозначным алфавитным оператором, а многозначным.
Можно построить алфавитный оператор, решающей и другие задачи преобразования лексической информации. Например ,задачу редактирования текстов, задачу составления рефератов статей и т.д.
Аналогично нетрудно представить в виде процессов реализации алфавитных операторов и многие другие процессы преобразования информации: оркестровку мелодии, решение математических задач, задач планирования производства и т.д.
Может показаться, что для характеристики преобразований непрерывной информации понятия алфавитного оператора недостаточно.
Но это не совсем так.
Восприятие и преобразование непрерывной информации всегда производятся при помощи приборов, в которых существует ряд ограничений, позволяющих рассматривать эту информацию как алфавитную:
1) Ограничение разрешающей способности прибора, воспринимающего информацию.
Достаточно близкие между собой точки участка пространства, на котором распределена рассматриваемая информация, воспринимаются прибором как одна точка. Отсюда вытекает возможность рассматривать эту информацию как информацию, заданную не на бесконечном, а лишь на конечном множестве точек;
2) Второе ограничение связано с чувствительностью прибора, воспринимающего информацию. Прибор может различать фактически лишь конечное число уровней величины, представляющей информацию.
3) Третье ограничение обусловлено тем, что полоса пропускания прибора не позволяет ему различать слишком быстрые изменения воспринимаемой величины.
Таким образом, после введения дискретного времени информация, воспринимаемая прибором за любой конечный отрезок времени, представляется в виде слова в конечном алфавите.
В любом случае основой теории алфавитных операторов являются способы их задания.
Когда область определения алфавитного оператора конечна, оператор может быть задан простой таблицей соответствия.
Все слова, входящие в Слова, получаемые в результате применения
область определения оператора.
В случае бесконечной области определения алфавитного оператора задание его с помощью таблицы невозможно.
В этом случае оператор задается системой правил, позволяющей за конечное число шагов найти выходное слово, соответствующее любому наперед заданному входному слову из области определения рассматриваемого оператора.
Алфавитные операторы, задаваемые с помощью конечной системы правил, принято называть алгоритмами.
Всякий алфавитный оператор является непременно алгоритмом.
Однако в понятии алфавитного оператора существенно лишь само соответствие, устанавливаемое между входными и выходными словами, а не способ, которым это соответствие устанавливается.
В понятии алгоритма, наоборот, основным является способ задания соответствия, устанавливаемого алгоритмом.
Таким образом, алгоритм – это алфавитный оператор вместе с правилами, определяющими его действия
Два алфавитных оператора считаются равными, если они имеют одну и ту же область определения и сопоставляют любому наперед заданному входному слову из этой области одинаковые выходные слова.
Два алгоритма считаются равными, если равны соответствующие им алфавитные операторы и совпадает система правил, задающих действия этих алгоритмов.
Два алгоритма считаются эквивалентными, если у них совпадают алфавитные операторы, но не совпадают способы их задания (система правил) .
Обычно в теории алгоритмов рассматриваются лишь такие алгоритмы, которым соответствуют однозначные алфавитные операторы. Всякий алгоритм такого рода любому входному слову относит только одно выходное слово.
Такие алгоритмы и соответствующие им алфавитные операторы называются детерминированными.
К числу других свойств алгоритмов относятся массовость и результативность.
Массовость – свойство алгоритма быть применимым для множества слов.
Результативность – свойство, обеспечивающее получение результата через конечное число шагов.
Из свойства результативности вытекает понятие области применимости алгоритма.
Областью применимости алгоритма называется множество слов, для которых алгоритм результативен.
Теперь эквивалентность алгоритмов может быть определена следующим образом.
Два алгоритма эквивалентны, если совпадают их области применимости и результаты переработки любого слова из этой области.
В общем случае различают еще случайные и самоизменяющиеся алгоритмы.
Алгоритм называется случайным, если в системе правил, описывающих алгоритм, предусматривается возможность случайного выбора тех или иных слов и тех или иных правил.
Алгоритм называется самоизменяющимся, если он не только перерабатывает входные слова, но и сам изменяется в процессе такой переработки.
Результат действия самоизменяющегося алгоритма на то или иное входное слово зависит не только от этого слова, но и от истории предыдущей работы алгоритма.
В теории алгоритмов большое внимание уделяется общим способам задания алгоритмов, характеризующимся свойством универсальности, то есть способам, которые позволяют задать алгоритм, эквивалентный любому наперед заданному алгоритму.
Всякий общий способ задания алгоритмов называется алгоритмической системой.
При описании алгоритмических систем используются специальные формализованные средства. Основные формализмы прикладной теории алгоритмов можно разделить на два направления: «алгебраическое» и «геометрическое».
«Алгебраическая» теория строится в некоторой конкретной символике, при которой алгоритмы рассматриваются как некоторые линейные тексты.
В «геометрической» теории алгоритмы строятся в виде множеств, между которыми вводятся связи, носящие характер отображений или бинарных отношений. При этом объекты часто представляются в виде графов, вершины которых задают элементы множества, а ребра – отношения между ними. Отображения в этом случае задаются в виде разметки вершин или ребер графа.
К первому направлению относятся такие алгоритмические системы как рекурсивныые функции, машины Тьюринга и Поста, операторные системы Ван-Хао, А.В. Ляпунова, логические схемы алгоритмов Ю.И.Янова и др.
Ко второму направлению относятся представления нормальных алгоритмов А.А.Маркова, в виде граф-схем, предложенных Л.А.Калужинным и другие.
0 коммент.:
Отправить комментарий