Формальные грамматики
Версия от 06:18, 10 ноября 2011; Filchenko (обсуждение | вклад) (→Определения: вынес обозначения, добавил забытое)
Определения
| Определение: |
| Нетерминал — элемент, представляющий некоторую сущность языка (например, часть формулы) и не имеющий конкретного значения. |
| Определение: |
| Терминал — элемент алфавита . |
| Определение: |
| Формальная грамматика — способ описания формального языка, представляющий собой четверку , где — алфавит, — набор нетерминалов, — начальный символ грамматики, — набор правил вывода |
| Определение: |
( выводится из за один шаг):
|
| Определение: |
| ( выводится из за ноль или более шагов): |
| Определение: |
| Язык грамматики — все последовательности терминалов, которые можно получить из начального символа по правилам вывода. . |
Обозначения
- Нетерминалы обозначаются заглавными буквами латинского алфавита.
- Терминалы обозначаются строчными буквами из начала латинского алфавита.
- Последовательности из терминалов (слова) обозначают строчными буквами из конца латинского алфавита.
- Последовательности из терминалов и нетерминалов обозначаются строчными буквами греческого алфавита.
Примеры грамматик
Правильные скобочные последовательности
Вывод строки :
Арифметические выражения
- — два выражения, соединенные действием
- — выражение, взятое в скобки
- — ноль
- — число, у которого первая цифра не ноль
- — действие
- — цифра, не являющаяся нулем
- — любая последовательность из цифр, возможно пустая
- — любая цифра
Вывод строки :
Левосторонний вывод для такой же строки:
Литература
- Хопкрофт Д., Мотвани Р., Ульман Д. — Введение в теорию автоматов, языков и вычислений, 2-е изд. : Пер. с англ. — Москва, Издательский дом «Вильямс», 2002. — 528 с. : ISBN 5-8459-0261-4 (рус.)