Язык Дика — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
м (rollbackEdits.php mass rollback)
 
Строка 1: Строка 1:
{| class="wikitable" align="center" style="color: red; background-color: black; font-size: 56px; width: 800px;"
 
|+
 
|-align="center"
 
|'''НЕТ ВОЙНЕ'''
 
|-style="font-size: 16px;"
 
|
 
24 февраля 2022 года российское руководство во главе с Владимиром Путиным развязало агрессивную войну против Украины. В глазах всего мира это военное преступление совершено от лица всей страны, всех россиян.
 
 
Будучи гражданами Российской Федерации, мы против своей воли оказались ответственными за нарушение международного права, военное вторжение и массовую гибель людей. Чудовищность совершенного преступления не оставляет возможности промолчать или ограничиться пассивным несогласием.
 
 
Мы убеждены в абсолютной ценности человеческой жизни, в незыблемости прав и свобод личности. Режим Путина — угроза этим ценностям. Наша задача — обьединить все силы для сопротивления ей.
 
 
Эту войну начали не россияне, а обезумевший диктатор. И наш гражданский долг — сделать всё, чтобы её остановить.
 
 
''Антивоенный комитет России''
 
|-style="font-size: 16px;"
 
|Распространяйте правду о текущих событиях, оберегайте от пропаганды своих друзей и близких. Изменение общественного восприятия войны - ключ к её завершению.
 
|-style="font-size: 16px;"
 
|[https://meduza.io/ meduza.io], [https://www.youtube.com/c/popularpolitics/videos Популярная политика], [https://novayagazeta.ru/ Новая газета], [https://zona.media/ zona.media], [https://www.youtube.com/c/MackNack/videos Майкл Наки].
 
|}
 
 
 
{{Определение
 
{{Определение
 
|id=def2
 
|id=def2

Текущая версия на 19:06, 4 сентября 2022

Определение:
Язык Дика (англ. Dyck language) — множество правильных скобочных структур вместе с пустой структурой, образующее язык над алфавитом [math]\{a, b\}[/math].


Определение:
Производящей функцией (англ. generating function) языка [math]L[/math] называется производящая функция [math]L(s) = l_0 + l_1 s + l_2 s^2 + \ldots,[/math] где [math]l_k[/math] есть число слов длины [math]k[/math] в языке [math]L[/math].


Правила вывода в языке Дика

Язык Дика является контекстно-свободным языком. Рассмотрим два правила вывода в языке Дика:

1) [math]r \longrightarrow \lambda[/math]
2) [math]r \longrightarrow arbr,[/math]

где [math]r[/math] — буква, не входящая в алфавит [math]\{a, b\}[/math],

стрелка [math]\longrightarrow[/math] заменяет фразу: если в слове есть буква [math]r[/math], то эту букву можно заменить на слово, стоящее справа от стрелки.

Правила вывода можно понимать следующим образом:

Всякое слово в языке Дика есть либо

1) пустое слово,
2) слово, в котором внутри самой левой пары соответственных скобок стоит некоторое слово языка Дика и после этой пары стоит слово языка Дика.

Ясно, что для каждого слова такое представление единственно.

Производящая функция для языка Дика

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

[math]D(a, b) = \lambda + ab + aabb + abab + aaabbb + aababb + \ldots[/math]

Теорема:
Ряд [math]D(a, b) = \lambda + ab + aabb + abab + aaabbb + aababb + \ldots[/math] удовлетворяет уравнению [math]D(a, b) = \lambda + aD(a, b)bD(a, b)[/math].
Доказательство:
[math]\triangleright[/math]

Действительно, в левой части равенства [math]D(a, b) = \lambda + aD(a, b)bD(a, b)[/math] записана сумма всех слов языка Дика. Равенство означает справедливость утверждения:

Всякое слово в языке Дика есть либо

1) пустое слово,
2) слово, в котором внутри самой левой пары соответственных скобок стоит некоторое слово языка Дика и после этой пары стоит слово языка Дика.
При этом такое представление единственно.
[math]\triangleleft[/math]

Чтобы перейти от некоммутативного производящего ряда к обычному, сделаем подстановку [math]a = s,\,b = s,\, \lambda = s^0 = 1[/math]. Уравнение [math]D(a, b) = \lambda + aD(a, b)bD(a, b)[/math] примет вид [math]D(s, s) = 1 + s^2D(s, s)[/math].

Отсюда, обозначив [math]D(s, s)[/math] через [math]d(s),[/math] получим [math]d(s) = 1 + s^2d(s)^2[/math]

Решение [math]d(s) = \dfrac{1 - \sqrt{1 - 4s^2}}{2s^2}[/math] этого уравнения совпадает с производящей функцией для чисел Каталана. Необходимость подстановки [math]s^2[/math] вместо [math]s[/math] объясняется тем, что в языке Дика длина слова, составленного из [math]n[/math] пар скобок, равна [math]2n[/math]: мы перечисляем слова по числу скобок, а не пар скобок.

См. также

Источники информации

  • С. А. Ландо: Лекции о производящих функциях
  • Гросс М., Лантен А.: Теория формальных грамматик