Удаление eps-правил из грамматики — различия между версиями
(→Пример) |
|||
Строка 1: | Строка 1: | ||
== Используемые определения == | == Используемые определения == | ||
{{Определение | {{Определение | ||
− | |definition = Правила вида <tex>A \to \varepsilon</tex> называются '''<tex>\varepsilon</tex>-правилами'''. | + | |definition = Правила вида <tex>A \to \varepsilon</tex> называются '''<tex>\varepsilon</tex>-правилами''' (''<tex>\varepsilon</tex> rule''). |
}} | }} | ||
{{Определение | {{Определение | ||
− | |definition = Нетерминал <tex>A</tex> называется '''<tex>\varepsilon</tex>-порождающим''', если <tex>A \Rightarrow^* \varepsilon</tex>. | + | |definition = Нетерминал <tex>A</tex> называется '''<tex>\varepsilon</tex>-порождающим''' (''<tex>\varepsilon</tex>-generating''), если <tex>A \Rightarrow^* \varepsilon</tex>. |
}} | }} | ||
Строка 48: | Строка 48: | ||
Подставив <tex>S</tex> вместо <tex>A</tex> в утверждение (*), видим, что <tex>w \in L(G)</tex> для <tex>w \ne \varepsilon</tex> тогда и только тогда, когда <tex>w \in L(G')</tex>. Так как после выполнения шага 5 алгоритма в <tex>G'</tex> могло добавиться только пустое слово <tex>\varepsilon</tex>, то язык, задаваемый КС грамматикой <tex>G'</tex>, совпадает с языком, задаваемым КС грамматикой <tex>G</tex>. | Подставив <tex>S</tex> вместо <tex>A</tex> в утверждение (*), видим, что <tex>w \in L(G)</tex> для <tex>w \ne \varepsilon</tex> тогда и только тогда, когда <tex>w \in L(G')</tex>. Так как после выполнения шага 5 алгоритма в <tex>G'</tex> могло добавиться только пустое слово <tex>\varepsilon</tex>, то язык, задаваемый КС грамматикой <tex>G'</tex>, совпадает с языком, задаваемым КС грамматикой <tex>G</tex>. | ||
}} | }} | ||
+ | |||
+ | === Время работы алгоритма === | ||
+ | Рассмотрим грамматику: | ||
+ | <tex> \Gamma = | ||
+ | \begin{array}{l l} | ||
+ | S\rightarrow T_1 T_2 T_3 ... T_n\\ | ||
+ | T_1\rightarrow t_1|\varepsilon\\ | ||
+ | T_2\rightarrow t_2|\varepsilon\\ | ||
+ | ...\\ | ||
+ | T_n\rightarrow t_n|\varepsilon | ||
+ | \end{array} | ||
+ | </tex>.<br> | ||
+ | <tex>\left| \Gamma \right| = O(n)</tex>. Из нетерминала <tex>S</tex> можно вывести <tex>2^n</tex> сочетаний нетерминалов <tex>T_i</tex>. Таким образом в худшем случае алгоритм работает за <tex>O(\left| \Gamma \right| ^ 2)</tex>.<br> | ||
+ | Однако если в грамматике устранены [[Удаление_длинных_правил_из_грамматики|длинные правила]], то алгоритм будет работать за <tex>O(\left| \Gamma \right|)</tex> и добавит в грамматику <tex>O(\left| \Gamma \right|)</tex> новых правил длинны <tex>O(1)</tex>. | ||
=== Пример === | === Пример === | ||
Строка 89: | Строка 103: | ||
Пусть после завершения алгоритма существуют нетерминалы такие, что они являются <tex>\varepsilon</tex>-порождающими, но не были найдены алгоритмом. Выберем из этих нетерминалов нетерминал <tex>B</tex>, из которого выводится <tex>\varepsilon</tex> за наименьшее число шагов. Тогда в грамматике есть правило <tex>B \rightarrow C_1C_2...C_k</tex>, где каждый нетерминал <tex>C_i</tex> — <tex>\varepsilon</tex>-порождающий. Каждый <tex>C_i</tex> входит в множество <tex>\varepsilon</tex>-порождающих нетерминалов, так как иначе вместо <tex>B</tex> необходимо было взять <tex>C_i</tex>. Следовательно, на одной из итераций алгоритма <tex>B</tex> уже добавился в множество <tex>\varepsilon</tex>-порождающих нетерминалов. Противоречие. Следовательно, алгоритм находит все <tex>\varepsilon</tex>-порождающие нетерминалы. | Пусть после завершения алгоритма существуют нетерминалы такие, что они являются <tex>\varepsilon</tex>-порождающими, но не были найдены алгоритмом. Выберем из этих нетерминалов нетерминал <tex>B</tex>, из которого выводится <tex>\varepsilon</tex> за наименьшее число шагов. Тогда в грамматике есть правило <tex>B \rightarrow C_1C_2...C_k</tex>, где каждый нетерминал <tex>C_i</tex> — <tex>\varepsilon</tex>-порождающий. Каждый <tex>C_i</tex> входит в множество <tex>\varepsilon</tex>-порождающих нетерминалов, так как иначе вместо <tex>B</tex> необходимо было взять <tex>C_i</tex>. Следовательно, на одной из итераций алгоритма <tex>B</tex> уже добавился в множество <tex>\varepsilon</tex>-порождающих нетерминалов. Противоречие. Следовательно, алгоритм находит все <tex>\varepsilon</tex>-порождающие нетерминалы. | ||
}} | }} | ||
+ | |||
+ | === Время работы алгоритма === | ||
+ | Данный алгоритм работает за <tex>O(\left| \Gamma \right| ^ 2)</tex>, однако используя [[Очередь|очередь]] можно ускорить его до <tex>O(\left| \Gamma \right|)</tex>. | ||
=== Пример === | === Пример === | ||
Строка 107: | Строка 124: | ||
Таким образом <tex>\varepsilon</tex>-порождающими нетерминалами являются <tex>A</tex>, <tex>B</tex>, <tex>C</tex> и <tex>S</tex>. | Таким образом <tex>\varepsilon</tex>-порождающими нетерминалами являются <tex>A</tex>, <tex>B</tex>, <tex>C</tex> и <tex>S</tex>. | ||
+ | |||
+ | == См. также == | ||
+ | * [[Контекстно-свободные_грамматики,_вывод,_лево-_и_правосторонний_вывод,_дерево_разбора|Контекстно-свободные грамматики]] | ||
+ | * [[Нормальная_форма_Хомского|Нормальная форма Хомского]] | ||
+ | * [http://en.wikipedia.org/wiki/Chomsky_normal_form Chomsky normal form] | ||
== Литература == | == Литература == |
Версия 14:35, 17 ноября 2013
Содержание
Используемые определения
Определение: |
Правила вида | называются -правилами ( rule).
Определение: |
Нетерминал | называется -порождающим ( -generating), если .
Алгоритм удаления ε-правил из грамматики
Вход: КС грамматика
Выход: КС грамматика без -правил (может присутствовать правило , но в этом случае не встречается в правых частях правил); .
- Добавить все правила из в .
- Найти все . -порождаюшие нетерминалы
- Для каждого правила вида (где — последовательности из терминалов и нетерминалов, — -порождающие нетерминалы) добавить в все возможные варианты правил, в которых либо присутствует, либо удалён каждый из нетерминалов .
- Удалить все -правила из .
- Если в исходной грамматике выводилось , то необходимо добавить новый нетерминал , сделать его стартовым, добавить правило .
Доказательство корректности
Теорема: |
Если грамматика была построена с помощью описанного выше алгоритма по грамматике , то . |
Доказательство: |
Сначала докажем, что, если не выполнять шаг 5 алгоритма, то получится грамматика
|
Время работы алгоритма
Рассмотрим грамматику:
. Из нетерминала можно вывести сочетаний нетерминалов . Таким образом в худшем случае алгоритм работает за .
Однако если в грамматике устранены длинные правила, то алгоритм будет работать за и добавит в грамматику новых правил длинны .
Пример
Рассмотрим грамматику:
, в которой , и являются -порождающими нетерминалами.- Переберём для каждого правила все возможные сочетания ε-порождающих нетерминалов и добавим новые правила:
- для
- для
- Удалим праила и
В результате мы получим новую грамматику без
-правил:Алгоритм поиска ε-порождающих нетерминалов
Вход: КС грамматика
Выход: множество -порождающих нетерминалов.
- Найти все -правила. Составить множество, состоящее из нетерминалов, входящих в левые части таких правил.
- Перебираем правила грамматики . Если найдено правило , для которого верно, что каждый принадлежит множеству, то добавить в множество.
- Если на шаге 2 множество изменилось, то повторить шаг 2.
Доказательство корректности
Теорема: |
Описанный выше алгоритм находит все -порождающие нетерминалы грамматики . |
Доказательство: |
Для доказательства корректности алгоритма достаточно показать, что, если множество Пусть после завершения алгоритма существуют нетерминалы такие, что они являются -порождающих нетерминалов на очередной итерации алгоритма не изменялось, то алгоритм нашел все -порождающие нетерминалы. -порождающими, но не были найдены алгоритмом. Выберем из этих нетерминалов нетерминал , из которого выводится за наименьшее число шагов. Тогда в грамматике есть правило , где каждый нетерминал — -порождающий. Каждый входит в множество -порождающих нетерминалов, так как иначе вместо необходимо было взять . Следовательно, на одной из итераций алгоритма уже добавился в множество -порождающих нетерминалов. Противоречие. Следовательно, алгоритм находит все -порождающие нетерминалы. |
Время работы алгоритма
Данный алгоритм работает за очередь можно ускорить его до .
, однако используяПример
Рассмотрим грамматику:
- Возьмём множество состоящее из -порождающих нетерминалов .
- Добавим в множество, так как правая часть правила состоит только из нетерминалов из множества.
- Повторим второй пункт для правила и получим множество .
- Больше нет нерассмотренных правил, содержащих справа только нетерминалы из множества.
Таким образом
-порождающими нетерминалами являются , , и .См. также
Литература
- Хопкрофт Д., Мотвани Р., Ульман Д. Введение в теорию автоматов, языков и вычислений, 2-е изд. : Пер. с англ. — Москва, Издательский дом «Вильямс», 2002. — С. 273: ISBN 5-8459-0261-4 (рус.)