Лемма о разрастании для КС-грамматик
Версия от 21:32, 23 января 2012; 192.168.0.2 (обсуждение)
Лемма (о разрастании КС-грамматик): |
Пусть контекстно-свободный язык над алфавитом , тогда существует такое , что для любого слова длины не меньше найдутся слова , для которых верно: и . — |
Доказательство: |
Грамматика любого контекстно-свободного языка может быть записана в нормальной форме Хомского (НФХ). Пусть — количество нетерминалов в грамматике языка , записанной в НФХ.
Выберем Таким образом, . Построим дерево разбора произвольного слова длиной больше, чем . Высотой дерева разбора назовем максимальное число нетерминальных символов на пути от корня дерева к листу. Так как грамматика языка записана в НФХ, то у любого нетерминала в дереве могут быть, либо два потомка нетерминала, либо один потомок терминал. Поэтому высота дерева разбора слова не меньше . Рассмотрим самый длинный путь от вершины, соответствующей стартовому нетерминалу,до листа. В нем будет не менее узлов, соответствующих нетерминалам. Следовательно, по принципу Дирихле найдется такой нетерминал , который раскрывается в дереве разбора на этом пути дважды. Если таких путей и, следовательно, нетерминалов несколько, то выберем нетерминал максимальной глубины, у которого в поддереве содержится такой же нетерминал. Тогда в качестве выберем кратчайшую строку из терминалов, которая выводится из . Далее рассмотрим путь от предпоследнего повторения нетерминала до последнего его вхождения в дерево. Если из вершины был сделан переход в левое поддерево, то строка, выведенная из правого поддерева, будет частью . Аналогично из левых поддеревьев получаем . Так как грамматика записана в НФХ, то либо , либо не будет пустой строкой, то есть условие выполнено. . |