Теорема Клини (совпадение классов автоматных и регулярных языков) — различия между версиями
Kirelagin (обсуждение | вклад) м |
|||
| Строка 7: | Строка 7: | ||
[[Файл:concat.png|200px|thumb|right|Автомат для конкатенации двух регулярных языков]] | [[Файл:concat.png|200px|thumb|right|Автомат для конкатенации двух регулярных языков]] | ||
[[Файл:Klenee.png|200px|thumb|right|Автомат для замыкания Клини регулярного языка]] | [[Файл:Klenee.png|200px|thumb|right|Автомат для замыкания Клини регулярного языка]] | ||
| − | 1. <tex>Reg \ | + | 1. <tex>Reg \subseteq Aut</tex>. |
Для доказательства будем строить автоматы, допускающие регулярные языки (см. картинки справа). При этом будем использовать индукцию по номеру поколения регулярного языка. | Для доказательства будем строить автоматы, допускающие регулярные языки (см. картинки справа). При этом будем использовать индукцию по номеру поколения регулярного языка. | ||
| Строка 26: | Строка 26: | ||
Итого, мы можем по регулярному выражению построить автомат, допускающий тот же язык. | Итого, мы можем по регулярному выражению построить автомат, допускающий тот же язык. | ||
| − | 2. <tex>Aut \ | + | 2. <tex>Aut \subseteq Reg</tex>. |
Для доказательства будем строить регулярное выражение, допускающее язык, заданный каким-то автоматом. Пусть задан автомат <tex>A</tex> с набором состояний <tex>Q = \left\{1, 2, \dots n \right\}</tex>. | Для доказательства будем строить регулярное выражение, допускающее язык, заданный каким-то автоматом. Пусть задан автомат <tex>A</tex> с набором состояний <tex>Q = \left\{1, 2, \dots n \right\}</tex>. | ||
Версия 19:11, 23 января 2012
| Теорема (Клини): |
Классы автоматных и регулярных языков совпадают. |
| Доказательство: |
|
1. . Для доказательства будем строить автоматы, допускающие регулярные языки (см. картинки справа). При этом будем использовать индукцию по номеру поколения регулярного языка. База. . Для этого достаточно построить автоматы для трех языков:
Индукционный переход. Умеем строить автоматы для языков -ого поколения. Будем строить для . Для этого достаточно научиться строить автоматы для следующих языков ():
Заметим, что по предположению индукции автоматы для могут быть построены. Итого, мы можем по регулярному выражению построить автомат, допускающий тот же язык. 2. . Для доказательства будем строить регулярное выражение, допускающее язык, заданный каким-то автоматом. Пусть задан автомат с набором состояний . Определим регулярные выражения, задающие следующие множества слов: , причем в качестве промежуточных вершин выступают только такие, у которых номер не более . Построим эти регулярные выражения:
Теперь нетрудно задать регулярное выражение для всего языка: , где — стартовое состояние, а — терминальные состояния исходного автомата. Таким образом, мы построили по автомату регулярное выражение, допускающее тот же самый язык. |