Существенно неоднозначные языки — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
Строка 13: Строка 13:
 
== Существенно неоднозначные языки ==
 
== Существенно неоднозначные языки ==
 
Язык называется существенно неоднозначным, если любая его грамматика неоднозначна.
 
Язык называется существенно неоднозначным, если любая его грамматика неоднозначна.
Пример такого языка: <tex>L = \{a^n b^n c^m d^m | m, n > 1\} \cup \{a^n b^m c^m d^n | m, n > 1\}</tex> - в нем слова вида <tex>a^k b^k c^k d^k</tex> во всех грамматиках имеют более одного дерева разбора.
+
Пример такого языка: <tex>0^a 1^b 2^c</tex>, где <tex>a=b \or b=c</tex>
+
Докажем, что <tex>\forall \Gamma \exists k: 0^k 1^k 2^k</tex> имеет хотя бы 2 дерева разбора.
Докажем это формально:
 
  
Единственный способ породить цепочки в которых поровну a и b {{---}} это использовать продукции, похожие на <tex>A \rightarrow aAb</tex>. Рассмотрим это более детально:
 
 
* Одинковое количество a, b может порождаться продукциями вида <tex>A \rightarrow aaabbb</tex>,
 
* продукциями вида <tex>A_1 \rightarrow aA_2b|ab</tex>, <tex>A_2 \rightarrow aA_1b|ab</tex>,
 
* продукциями вида <tex>S \rightarrow Ab</tex>, <tex>A \rightarrow aAb|a</tex>
 
  
Но в любом случае парами. Так же с c и d, b и c, a и d. А это значит, что <tex>a^k b^k c^k d^k</tex> порождается как минимум двумя способами.
 
 
   
 
   
 
{{Теорема
 
{{Теорема
 
|statement=
 
|statement=
 
Для языка принимаемого ДМП-автоматом существует однозначная КС-грамматика}}
 
Для языка принимаемого ДМП-автоматом существует однозначная КС-грамматика}}

Версия 22:30, 15 января 2011

Неоднозначные грамматики

Неоднозначной грамматикой называется грамматика, по которой для одной цепочки существует более одного дерева разбора.

Пример:

Рассмотрим грамматику [math]E \rightarrow E + E | E * E[/math] и выводимую цепочку[math]E + E * E[/math]. Ее можно вывести двумя способами:

[math]E \Rightarrow E + E \Rightarrow E + E * E[/math]

[math]E \Rightarrow E * E \Rightarrow E + E * E[/math]

Эта граматика неоднозначна.

Существенно неоднозначные языки

Язык называется существенно неоднозначным, если любая его грамматика неоднозначна. Пример такого языка: [math]0^a 1^b 2^c[/math], где [math]a=b \or b=c[/math] Докажем, что [math]\forall \Gamma \exists k: 0^k 1^k 2^k[/math] имеет хотя бы 2 дерева разбора.


Теорема:
Для языка принимаемого ДМП-автоматом существует однозначная КС-грамматика