Лемма о разрастании для КС-грамматик — различия между версиями
(→Пример не КС-языка, для которого выполняется лемма) |
м (→См. также) |
||
Строка 48: | Строка 48: | ||
== См. также == | == См. также == | ||
− | [[Лемма_Огдена|Лемма Огдена]] | + | * [[Лемма_Огдена|Лемма Огдена]] |
== Источники == | == Источники == |
Версия 18:26, 1 ноября 2016
Содержание
Лемма о разрастании для КС-грамматик
Лемма (о разрастании КС-грамматик): |
Пусть контекстно-свободный язык над алфавитом , тогда существует такое , что для любого слова длины не меньше найдутся слова , для которых верно: и . — |
Доказательство: |
Грамматика любого контекстно-свободного языка может быть записана в нормальной форме Хомского (НФХ). Пусть — количество нетерминалов в грамматике языка , записанной в НФХ.
Выберем . Построим дерево разбора произвольного слова длиной больше, чем . Высотой дерева разбора назовем максимальное число нетерминальных символов на пути от корня дерева к листу. Так как грамматика языка записана в НФХ, то у любого нетерминала в дереве могут быть, либо два потомка нетерминала, либо один потомок терминал. Поэтому высота дерева разбора слова не меньше .Выберем путь от корня дерева к листу максимальной длины. Количество нетерминалов в нем не меньше, чем , следовательно, найдется такой нетерминал , который встречается на этом пути дважды. Значит, в дереве разбора найдется нетерминал , в поддереве которого содержится нетерминал . Выберем такой нетерминал , чтобы в его поддереве содержался такой же нетерминал и длина пути от него до корня была максимальна среди всех нетерминалов, содержащих в поддереве такой же нетерминал.Найдем слова .
Покажем, что Таким образом, в рамках нашей грамматики мы можем построить цепочку вывода: . Допустим, что . Тогда высота поддерева с корнем в вершине, соответствующей выбранному , не меньше . Рассмотрим поддерево вершины, в котором содержится нетерминал . Тогда высота этого поддерева не меньше . Рассмотрим путь максимальной длины от корня этого поддерева к листу. В нем содержится не менее нетерминалов, причем не содержится стартовый нетерминал. Следовательно, на этом пути найдутся два одинаковых нетерминала, что противоречит условию наибольшей удаленности от корня выбранного ранее нетерминала . Получили противоречие. Поэтому . . |
Замечание. Условие леммы не является достаточным для контекстно-свободности языка. Но, в силу необходимости условия, данная лемма часто используется для доказательства неконтекстно-свободности языков.
Пример доказательства неконтекстно-свободности языка с использованием леммы
Рассмотрим язык
. Покажем, что он не является контекстно-свободным.Для фиксированного
рассмотрим слово . Пусть разбили на произвольным образом. Так как , то в слове не содержится либо ни одного символа , либо ни одного символа . Для любого такого разбиения выбираем и получаем, что количество символов изменилось, а количество либо , либо осталось тем же. Очевидно, что такое слово не принадлежит рассмотренному языку. Значит, язык не является контекстно-свободным по лемме о разрастании для КС-грамматик.Пример не КС-языка, для которого выполняется лемма
Рассмотрю язык
Докажем, что он неконтестно-свободный. Для этого воспользуемся Леммой Огдена. Для фиксированного рассмотрим слово . Пометим все символы и . Пусть разбили на , так что содержит выделенную позицию; и содержат выделенные позиции и содержат не более выделенных позиций. Тогда очевидно, что должно содержать одинаковое число символов и , иначе выбираем и тогда количество символов и станет разным. Пусть символов в будет . Так же очевидно, что не содержит символов , так как содержат не более выделенных позиций, но точно содержит символ . Тогда выберем и получим слово , которое не принадлежит рассмотренному языку. Значит не является контекстно-свободным.
Докажем, что язык удовлетворяет лемме о разрастании. Выберем
. Это значит, что длина рассматриваемых слов не меньше . Рассмотрю случаи:- . Выберем , , .
- . Выберем , , , , .
- , где . Выберем , , , , .
- . Выберем , , , , .
- . Выберем , , , , .
- , где . Выберем , , .
Таким образом язык
не контекстно-свободный, но удовлетворяет второй части леммы.См. также
Источники
- Хопкрофт Д., Мотвани Р., Ульман Д. — Введение в теорию автоматов, языков и вычислений, 2-е изд. : Пер. с англ. — Москва, Издательский дом «Вильямс», 2002. — 528 с. : ISBN 5-8459-0261-4 (рус.)