Опубликован: 06.08.2007 | Доступ: свободный | Студентов: 1933 / 1083 | Оценка: 4.45 / 4.29 | Длительность: 18:50:00
Специальности: Программист
Лекция 4:

Лексический анализ

Конечные автоматы

Регулярные выражения, введенные ранее, служат для описания регулярных множеств. Для распознавания регулярных множеств служат конечные автоматы. Недетерминированный конечный автомат (НКА) - по определению есть пятерка M = (Q, T, D, q0, F), где

  1. Q - конечное множество состояний,
  2. T - конечное множество допустимых входных символов (входной алфавит),
  3. D - функция переходов (отображающая множество Q \times (T \cup \{e\}) во множество подмножеств множества Q ), определяющая поведение управляющего устройства,
  4. q_0 \in Q - начальное состояние управляющего устройства,
  5. F \subseteq Q - множество заключительных состояний.

Работа конечного автомата представляет собой некоторую последовательность шагов, или тактов. Такт определяется текущим состоянием управляющего устройства и входным символом, обозреваемым в данный момент входной головкой. Сам шаг состоит из изменения состояния и, возможно, сдвига входной головки на одну ячейку вправо ( рис. 3.2.).

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


Рис. 3.2.

Пусть M = (Q, T, D, q0, F) - НКА. Конфигурацией автомата M называется пара (q, w) \in Q \times T^*, где q - текущее состояние управляющего устройства, а w - цепочка символов на входной ленте, состоящая из символа под головкой и всех символов справа от него. Конфигурация ( q0, w ) называется начальной, а конфигурация ( q, e ), где q \in F - заключительной (или допускающей). Тактом автомата M называется бинарное отношение \vdash, определенное на конфигурациях M следующим образом: если p \in D(q, a), где a \in T \cup \{e\}, \; \text{то} \; (q, aw) \vdash (p, w) для всех w \in T^*.

Будем обозначать символом \vdash^+ (\vdash^*) транзитивное (рефлексивно-транзитивное) замыкание отношения \vdash. Будем говорить, что автомат M допускает цепочку w, если (q_0, w) \vdash^* (q, e) для некоторого q \in F. Языком, допускаемым, (распознаваемым, определяемым) автоматом M, (обозначается L(M) ), называется множество входных цепочек, допускаемых автоматом M. То есть,

L(M)=\{w \mid w \in T^* \; \text{и} \; (q_0,w) \vdash^* (q,e) \; \text{для некоторого} \; q \in F \}

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

Пусть M = (Q, T, D, q0, F) - НКА. Будем называть M детерминированным конечным автоматом (ДКА), если выполнены следующие два условия:

  1. D(q, e) = \varnothing, для любого q \in Q, и
  2. D(q, a) содержит не более одного элемента для любых q \in Q и a \in T.

Так как функция переходов ДКА содержит не более одного элемента для любой пары аргументов, для ДКА мы будем пользоваться записью D(q, a)=p вместо D(q, a)={p}.

Конечный автомат может быть изображен графически в виде диаграммы, представляющей собой ориентированный граф, в котором каждому состоянию соответствует вершина, а дуга, помеченная символом a \in T \cup \{e\}, соединяет две вершины p и q, если p \in D(q, a). На диаграмме выделяются начальное и заключительные состояния (в примерах ниже, соответственно, входящей стрелкой и двойным контуром).

Пример 3.3. Пусть L = L(r), где r = (a|b)*a(a|b)(a|b).

    1. Недетерминированный конечный автомат M, допускающий язык L:

      M = {{1, 2, 3, 4}, {a, b}, D, 1, {4}},

      где функция переходов D определяется так:
      \begin{align*}
& D(1, a) = \{1, 2\}, & D(3, a) = \{4\}, \\
& D(1, b) = \{1\}, & D(2, b) = \{3\}, \\
& D(2, a) = \{3\}, & D(3, b) = \{4\}.
\end{align*}
      Диаграмма автомата приведена на рис. 3.3 а.
    2. Детерминированный конечный автомат M, допускающий язык L:

      M = {{1, 2, 3, 4, 5, 6, 7, 8}, {a, b}, D, 1, {3, 5, 6, 8}}

      где функция переходов D определяется так:

      \begin{align*}
& D(1, a) = 2, & D(5, a) = 8, \\
& D(1, b) = 1, & D(5, b) = 6, \\
& D(2, a) = 4, & D(6, a) = 2, \\
& D(2, b) = 7, & D(6, b) = 1, \\
& D(3, a) = 3, & D(7, a) = 8, \\
& D(3, b) = 5, & D(7, b) = 6, \\
& D(4, a) = 3, & D(8, a) = 4, \\
& D(4, b) = 5, & D(8, b) = 7.
\end{align*}

      Диаграмма автомата приведена на рис. 3.3 б.


Рис. 3.3.

Пример 3.4. Диаграмма автомата, допускающего множество чисел в десятичной записи, приведена на рис. 3.4.


Рис. 3.4.

Пример 3.5. Анализ цепочек.

  1. При анализе цепочки w = ababa автомат из примера рис. 3.3, а, может сделать следующую последовательность тактов:
    (1, ababa) \vdash (1, baba) \vdash (1, aba) \vdash (2, ba) \vdash (3, a) \vdash (4, e).
    Состояние 4 является заключительным, отсюда, цепочка w допускается этим автоматом.
  2. При анализе цепочки w = ababab автомат из примера рис. 3.3, б, должен сделать следующую последовательность тактов:
    (1, ababab) \vdash (2, babab) \vdash (7, abab) \vdash (8, bab) \vdash (7, ab) \vdash (8, b) \vdash (7, e).
    Так как состояние 7 не является заключительным, цепочка w не допускается этим автоматом.