Interested Article - Лемма о разрастании

Лемма о накачке ( лемма о разрастании , лемма-насос ; англ. pumping lemma ) — важное утверждение теории автоматов , позволяющее во многих случаях проверить, является ли данный язык автоматным . Поскольку все являются автоматными, эту проверку имеет смысл делать только для бесконечных языков. Термин «накачка» в названии леммы отражает возможность многократного повторения некоторой подстроки в любой строке подходящей длины любого бесконечного автоматного языка.

Существует также лемма о разрастании для контекстно-свободных языков , ещё более общее утверждение — .

Формулировка

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

Запись в кванторах:

.

Доказательство

Пусть автоматный язык содержит бесконечное число цепочек и предположим, что распознаётся детерминированным конечным автоматом с состояниями . Для проверки заключения леммы выберем произвольную цепочку этого языка, которая имеет длину .

Если конечный автомат распознаёт , то цепочка допускается этим автоматом, то есть в автомате существует путь длины из начального в одно из заключительных состояний, помеченный символами цепочки . Путь этот не может быть простым, он должен проходить ровно через состояние, в то время как автомат имеет состояний. Это значит, что этот путь проходит по меньшей мере два раза через одно и то же состояние автомата , то есть на этом пути есть цикл с повторяющимся состоянием. Пусть это повторяющееся состояние .

Разделим цепочку на три части, так что , где — подцепочка, переводящая из состояния опять в состояние , и — подцепочка, переводящая из состояния в заключительное состояние. Заметим, что как , так и могут быть пустыми, но подцепочка не может быть пустой. Но тогда очевидно, что автомат должен допускать также и цепочку , поскольку повторяющаяся подцепочка снова проходит по циклическому пути из в , а также и цепочку , и любую вида .

Это рассуждение и составляет доказательство леммы о накачке.

Обратная формулировка

Другая форма этой леммы, которую иногда удобнее применять, чтобы доказать неавтоматность некоторого языка, для языка над алфавитом состоит в следующем — если имеет место:

то язык — неавтоматный.

Для доказательства неавтоматности языка можно также пользоваться тем фактом, что пересечение регулярных языков регулярно. Так, непосредственно применить лемму о накачке к языку правильных скобочных структур в алфавите проблематично, но пересечение его с языком даёт язык , неавтоматность которого тривиально следует из леммы о накачке.

Литература

Ссылки

  • Пентус, А. Е., Пентус, М. Р. . М., 2004
  • Серебряков В. А. , Галочкин М. П., Гончар Д. Р., Фуругян М. Г. — М.: МЗ-Пресс, 2006 г., 2-е изд. — ISBN 5-94073-094-9
  • Винокуров Н.С. // Сиб. матем. журнал, 2005, Том 46, № 1. (недоступная ссылка с 13-05-2013 [3901 день] — )
Источник —

Same as Лемма о разрастании