Опубликован: 19.11.2012 | Уровень: для всех | Доступ: платный | ВУЗ: Национальный исследовательский университет "Высшая Школа Экономики"
Лекция 6:

Информационные технологии

< Лекция 5 || Лекция 6: 123456 || Лекция 7 >

Основные понятия теории формальных языков

Формальные языки являются упрощенными моделями реально существующих естественных и искусственных языков. Как и реальные языки, формальный язык состоит из множества слов, составленных из букв. Прежде чем дать точное определение формального языка, рассмотрим некоторые вспомогательные понятия.

Алфавитом называется конечное непустое множество знаков. Обычно подразумевается, что это множество линейно упорядочено. Условимся обозначать алфавиты символом \sum. Наиболее часто используются следующие алфавиты.

  1. B=\{0, 1\} - бинарный, или двоичный, алфавит, состоящий из двух знаков: 0 и 1.
  2. \sum=\{а,b, \dots ,z\} - множество строчных букв английского алфавита.
  3. Множество ASCII-символов или множество всех печатных ASCII-символов.
  4. Множество десятичных цифр D=\{0, 1, 2, 3, 4, 5, 6, 7, 8, 9\} является алфавитом, с помощью которого записываются неотрицательные целые числа.
  5. Алфавит H=\{0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f\} также служит для записи неотрицательных целых чисел в шестнадцатеричной системе счисления.
  6. Алфавит H=\{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, +, -, *, /, (, )\} позволяет записывать арифметические выражения над целыми числами.

Следует отметить, что алфавит H содержит 10 десятичных цифр т. е. B \bigcup D \bigcup H .

Слово или цепочка - это конечная последовательность знаков некоторого алфавита. Например, 01101 - это цепочка в бинарном алфавите B = \{0,1\}. Цепочки 15903 и 15df10 являются цепочками в алфавите D и H соответственно.

Пустая цепочка - это цепочка, не содержащая ни одного символа. Эту цепочку, обозначаемую е, можно рассматривать как цепочку в любом алфавите.

Часто бывает необходимо или удобно классифицировать слова по их длине, т.е. по числу позиций, которые занимают знаки в слове. Например, слово 01101 имеет длину 5. Обычно говорят, что длина цепочки - это число знаков в ней. Это определение широко распространено, но не вполне корректно. Так, в цепочке 01101 всего 2 символа, но число позиций в ней - пять, поэтому она имеет длину 5. Все же следует иметь в виду, что часто пишут "число знаков", подразумевая "число позиций".

Длину некоторой цепочки \omega обычно обозначают |\omega|. Например, |011| = |101| = |f50| = 3, а |\varepsilon| = 0.

Степени алфавита. Для множества всех цепочек определенной длины, состоящих из символов некоторого алфавита , удобно использовать, по аналогии с декартовыми степенями множеств, знак степени. Обозначим через A^k множество всех слов длины k, состоящих из знаков алфавита A. Данное множество с точностью до обозначений его элементов совпадает с декартовым произведением \overbrace{A \times A \times \dots \times A}^k. Различие заключается в том, что элементы декартового произведения обычно заключаются в скобки, а слова из A^k записываются без скобок.

Рассмотрим примеры такой записи A^0=\{\varepsilon\} независимо от алфавита A, т.е. \varepsilon - единственное слово длины 0. Для A=\{0, 1\} A^1=\{0, 1\}, A^2=\{00, 01, 10, 11\}, A^3=\{000, 001, 010, 011, 100, 101, 110, 111\} и так далее. Отметим, что между A и A^1 есть небольшое различие. Дело в том, что A есть алфавит, и его элементы 0 и 1 являются символами, а A^1 является множеством слов, и его элементы - это слова 1 и 0, каждое длиной 1. Мы не будем вводить разные обозначения для этих множеств, полагая, что из контекста будет понятно, является {0,1} или подобное ему множество алфавитом или же множеством цепочек.

Множество всех слов над алфавитом A принято обозначать A^*. Так, например \{0,1\}^* = \{\varepsilon, 0, 1, 00, 01, 10, 11, 000, \dots\}. По-другому это множество можно записать в виде А^*= A^0 \bigcup A^1 \bigcup A^2 \bigcup \dots

Множество всех непустых слов в алфавите A обозначают через A^+. Таким образом, имеют место следующие равенства:

А^+=А^1 \bigcup А^2 \bigcup А^3 \bigcup \dots\\
A^* =A^+\bigcup \{\varepsilon\}

Конкатенация слов. Пусть \alpha и \beta - слова. Тогда \alpha \cdot \beta обозначает их конкатенацию (соединение), т.е. слово, в котором последовательно записаны слова \alpha и \beta. Более строго, если \alpha - слово из i символов: \alpha = a_1 a_2 \dots a_j, а \beta - слово из j символов \beta = b_1 b_2 \dots b_j, то \alpha \beta - это слово длины i+j, \alpha \cdot \beta =a_1a_2 \dots a_ib_1b_2 \dots b_J.

Конкатенацию можно рассматривать как алгебраическую операцию на множестве всех слов в алфавите A^*, которая любым словам \alpha и \beta из A^* сопоставляет слово из A^*. Эта операция обладает некоторыми привычными свойствами алгебраических операций. Так, конкатенация является ассоциативной операцией, то есть для любых слов \alpha, \beta, \gamma справедливо равенство (\alpha \cdot \beta) \cdot \gamma= \alpha \cdot (\beta \cdot \gamma). Скобки в этом выражении определяют порядок выполнения операций конкатенации. Доказательство ассоциативности следует непосредственно из определения операции конкатенации. Операция конкатенации не является перестановочной (коммутативной), что следует из следующего примера.

Пусть \alpha = 10010 и \beta = 001. Тогда \alpha \cdot \beta = 10010001, а \beta \cdot \alpha = 00110010 и, следовательно, \alpha \cdot \beta \ne \beta \cdot \alpha.

Для пустого слова \varepsilon и любого слова \omega справедливы равенства \omega \cdot \varepsilon = \omega. Таким образом, \varepsilon является единицей (нейтральным элементом) относительно операции конкатенации, поскольку результат ее конкатенации с любым словом дает то же самое слово (аналогично тому, как 0, нейтральный элемент относительно сложения, при сложении с любым числом x дает число x). Описанные выше свойства операции конкатенации означают, что множество всех слов A^* является (свободным) моноидом относительно операции конкатенации [29].

Если \alpha-\beta \delta, то \delta называется началом, или префиксом, слова \alpha, а \beta - окончанием, или постфиксом, слова \alpha.

Множество всех слов можно представить графически в виде помеченного корневого дерева (дерева с выделенной вершиной, называемой корнем). Вершинам дерева соответствуют слова в алфавите A. Поэтому это дерево можно назвать словарным деревом, а поскольку все слова представлены в этом дереве, то его также можно назвать словарным универсумом. Это дерево имеет ярусное строение. На одном ярусе располагаются все слова одинаковой длины.

На рис.6.3 изображен фрагмент словарного универсума для случая, когда алфавит состоит из двух знаков, то есть A=\{0, 1\}.

Фрагмент словарного дерева (универсума) для алфавита {0, 1)

Рис. 6.3. Фрагмент словарного дерева (универсума) для алфавита {0, 1)

Опишем процедуру построения словарного дерева. Построение начинается с вершины, которая является корнем дерева и которая соответствует пустому слову \varepsilon. Эта (единственная) вершина образует нулевой ярус (уровень) дерева. Первый ярус дерева состоит из m вершин (m - число букв в алфавите A), которые соединены с корнем ребрами, помеченными буквами алфавита A. Вершины первого уровня соответствуют всем однобуквенным словам, которые получаются конкатенацией букв, помечающих ребра, с пустым словом.

Дальнейшее построение дерева выполняется аналогичным образом. Если k-й уровень дерева сформирован, то есть в дереве уже имеется m^k вершин, соответствующих всем словам длины k, к каждой вершине k-го уровня присоединяется k вершин (k+1) -го уровня посредством ребер, помеченных буквами алфавита A. Любой вершине (k+1)-го уровня соответствует слово, которое получается конкатенацией некоторого k-буквенного слова и буквы, помечающей ребро между этими словами.

Таким образом, из процедуры построения дерева следует, что ребром в дереве соединяются только те вершины, которым соответствуют слова, отличающиеся по длине на 1. При этом более длинное слово является конкатенацией более короткого слова и буквы, помечающей ребро. Ясно также, что любое слово \beta, соответствующее вершине, которая лежит на пути из корня дерева к вершине, соответствующей слову \alpha, является пре-фиксом слова \alpha, то есть \alpha=\beta \cdot \gamma, \gamma \in A^*.

Рассмотренные выше понятия и примеры позволяют сформулировать точное определение формального языка. Пусть A - некоторый фиксированный алфавит. Множество слов, каждое из которых принадлежит A^*, называют формальным языком. Иными словами, если A - алфавит и L \subset A^*, то L - это язык над A или в A. Отметим, что язык в A не обязательно должен содержать цепочки, в которые входят все символы A. Поэтому если известно, что L является языком в A, то можно утверждать, что L - это язык над любым алфавитом, содержащим A.

Однако оправданием использования термина "язык" для множества L \subset A^* может служить то, что и обычные языки можно рассматривать как множества цепочек (слов). Возьмем в качестве примера русский язык, где набор всех литературных русских слов есть множество цепочек в алфавите (русских же букв). Еще один пример - язык программирования С или любой другой язык программирования, в котором правильно написанные программы представляют собой подмножество множества всех возможных цепочек, а цепочки состоят из символов алфавита данного языка. Этот алфавит является подмножеством символов ASCII. Алфавиты для разных языков программирования могут быть различными, хотя обычно они состоят из прописных и строчных букв, цифр, знаков пунктуации и математических символов.

Существует, однако, множество других языков. Приведем несколько примеров.

Язык, состоящий из всех цепочек, в которых n единиц следуют за n нулями для некоторого n > 0: \{\varepsilon, 01, 0011, 000111, \dots\}.

Множество цепочек, состоящих из 0 и 1 и содержащих поровну тех и других: \{\varepsilon, 01, 10, 0011, 1001, \dots\}.

Множество двоичных записей простых чисел: \{10, 11, 101, 111, 1011, \dots \}.

Множество L_B всех правильных скобочных выражений, A = \{(, )\}. ((()())())\in L_B, (()())) \notin L_B.

А^* - язык для любого алфавита A.

\varnothing - пустой язык в любом алфавите.

\{\varepsilon\} - язык, содержащий одну лишь пустую цепочку. Он также является языком в любом алфавите. Заметим, что \varnothing ne \{\varepsilon\}; первый не содержит вообще никаких цепочек, а второй состоит из одной цепочки.

Единственное существенное ограничение для множеств, которые могут быть языками, состоит в том, что все алфавиты конечны.

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

Однако некоторые языки и могут содержать бесконечное число цепочек, но эти цепочки должны быть составлены из символов некоторого фиксированного конечного алфавита. В общем случае язык - это бесконечное множество слов. В этом заключается сложность работы с языками, в частности, их задание или описание. Несмотря на то, что язык содержит бесконечное число слов, желательно, чтобы описание такого языка было конечным. Один из подходов заключается в том, что применяется процедура (называемая грамматикой) построения слов точно определенным способом с применением правил грамматики. Другой подход использует алгоритм, который для каждого слова однозначно определяет, принадлежит ли оно языку или нет.

< Лекция 5 || Лекция 6: 123456 || Лекция 7 >
Фахруддин хемракулыев
Фахруддин хемракулыев
Шерхон Давлатов
Шерхон Давлатов

Почему тесты (1,2,3..) не работают. Хочу пройти тест но не получается

Денис Шаяхметов
Денис Шаяхметов
Россия, г. Нижневартовск
Кирилл Коршук
Кирилл Коршук
Беларусь, Минск, Международный университет МИТСО