Лемма о разрастании для КС-грамматик — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
(В процессе редакции)
 
Строка 6: Строка 6:
 
|proof=
 
|proof=
 
[[Файл:Consp_lemma.png||left|240px|]] Пусть <tex>L</tex> — контекстно-свободный язык над алфавитом <tex>\Sigma</tex>. Тогда его грамматика может быть записана в [[Нормальная форма Хомского|нормальной форме Хомского (НФХ)]]. Пусть <tex>m</tex> — количество нетерминалов в полученной грамматике.
 
[[Файл:Consp_lemma.png||left|240px|]] Пусть <tex>L</tex> — контекстно-свободный язык над алфавитом <tex>\Sigma</tex>. Тогда его грамматика может быть записана в [[Нормальная форма Хомского|нормальной форме Хомского (НФХ)]]. Пусть <tex>m</tex> — количество нетерминалов в полученной грамматике.
<br/> Выберем <tex>n=2^{m}</tex>. Построим дерево разбора слова <tex>\omega</tex>. Так как из одного нетерминала выводится либо два нетерминала, либо терминальный символ, то дерево разбора <tex>\omega</tex> будет бинарным, причем его высота не меньше <tex>m</tex>. Следовательно, по принципу Дерихле найдется такой нетерминал <tex>A</tex>, который раскрывается в дереве разбора дважды. Если таких нетерминалов несколько, то выберем нетерминал максимальной глубины, у которого в поддереве содержится такой же нетерминал. Тогда в качестве <tex>x</tex> выберем кратчайшую строку из терминалов, которая выводится из <tex>A</tex>.
+
<br/> Выберем <tex>n=2^{m}</tex>. Построим дерево разбора слова <tex>\omega</tex>. Так как из одного нетерминала выводится либо два нетерминала, либо терминальный символ, то дерево разбора <tex>\omega</tex> будет бинарным, причем его высота не меньше <tex>m</tex>. Следовательно, по принципу Дерихле найдется такой нетерминал <tex>A</tex>, который раскрывается в дереве разбора дважды. Если таких нетерминалов несколько, то выберем нетерминал максимальной глубины, у которого в поддереве содержится такой же нетерминал. Тогда в качестве <tex>x</tex> выберем кратчайшую строку из терминалов, которая выводится из <tex>A</tex>. Далее рассмотрим путь от предпоследнего повторения нетерминала <tex> A</tex> до последнего его вхождения в дерево. Если из вершины был сделан переход в левое поддерево, то строка, выведенная из правого поддерева будет частью <tex>y</tex>. Аналогично из левых поддеревьев получаем <tex>v</tex>. Так как грамматика записана в НФХ, то либо <tex>v</tex>, либо <tex>y</tex> не будет пустой строкой, то есть условие <tex>|vy|>0</tex> выполнено.
 +
<br/> Таким образом, <tex>S =>^{*} uAz =>^{*} uvAyz =>^{*} uvvAyyz =>^{*} uv^{k}Ay^{k}z =>^{*} uv^{k}xy^{k}z</tex>
 +
}}

Версия 05:00, 27 ноября 2011

Лемма (о разрастании КС-грамматик):
Пусть [math]L[/math]контекстно-свободный язык над алфавитом [math]\Sigma[/math], тогда существует такое [math]n[/math], что для любого слова [math] \omega \in L[/math] длины не меньше [math]n[/math] найдутся слова [math] u,v,x,y,z \in \Sigma^*[/math], для которых верно: [math]uvxyz=\omega, vy\neq \varepsilon, |vxy|\leqslant n[/math] и [math]\forall k \geqslant 0~uv^{k}xy^{k}z\in L[/math].
Доказательство:
[math]\triangleright[/math]
Consp lemma.png
Пусть [math]L[/math] — контекстно-свободный язык над алфавитом [math]\Sigma[/math]. Тогда его грамматика может быть записана в нормальной форме Хомского (НФХ). Пусть [math]m[/math] — количество нетерминалов в полученной грамматике.


Выберем [math]n=2^{m}[/math]. Построим дерево разбора слова [math]\omega[/math]. Так как из одного нетерминала выводится либо два нетерминала, либо терминальный символ, то дерево разбора [math]\omega[/math] будет бинарным, причем его высота не меньше [math]m[/math]. Следовательно, по принципу Дерихле найдется такой нетерминал [math]A[/math], который раскрывается в дереве разбора дважды. Если таких нетерминалов несколько, то выберем нетерминал максимальной глубины, у которого в поддереве содержится такой же нетерминал. Тогда в качестве [math]x[/math] выберем кратчайшую строку из терминалов, которая выводится из [math]A[/math]. Далее рассмотрим путь от предпоследнего повторения нетерминала [math] A[/math] до последнего его вхождения в дерево. Если из вершины был сделан переход в левое поддерево, то строка, выведенная из правого поддерева будет частью [math]y[/math]. Аналогично из левых поддеревьев получаем [math]v[/math]. Так как грамматика записана в НФХ, то либо [math]v[/math], либо [math]y[/math] не будет пустой строкой, то есть условие [math]|vy|\gt 0[/math] выполнено.


Таким образом, [math]S =\gt ^{*} uAz =\gt ^{*} uvAyz =\gt ^{*} uvvAyyz =\gt ^{*} uv^{k}Ay^{k}z =\gt ^{*} uv^{k}xy^{k}z[/math]
[math]\triangleleft[/math]