- •Вопрос 1 Трансляторы , интерпретаторы и компиляторы
- •Вопрос 2
- •Вопрос3 Понятие о грамматике языка
- •Вопрос 4
- •Вопрос 4 Способы задания схем грамматик
- •Вопрос 5 Классификация грамматик и языков по Хомскому (грамматики классифицируются по виду их правил вывода)
- •Вопрос 6 *каша* думайте сами что и куда писать
- •Вопрос 6. Парт 2 Разбор цепочек
- •Преобразования грамматик
- •Вопрос 7
- •Вопрос 8 Простейшие способы организации таблицы идентификаторов
- •Вопрос 9 Автоматные грамматики и конечные автоматы
- •Вопрос 10 Регулярные выражения. Свойства регулярных выражений
- •Вопрос 11
- •Вопрос 12.1.
- •Вопрос 12.2
- •1. Для каждой упорядоченной пары терминальных символов выполняется не более чем одно из трех отношений предшествования:
- •Вопрос 13
- •Вопрос 14
- •Вопрос 15
- •Вопрос 16
- •Вопрос 17
- •Вопрос 18
- •Вопрос 19
- •Вопрос 20 Распознаватель на основе алгоритма «сдвиг-свертка»
- •Вопрос 21 Метод рекурсивного спуска
- •Вопрос 22
- •Вопрос 23 внутренние формы представления программы
- •Вопрос 24 Оптимизация объектного кода методом свертки
- •Оптимизация объектного кода методом исключения лишних операций
- •Общий алгоритм генерации и оптимизации объектного кода
Вопрос 12.1.
Грамматикой простого предшествования называют такую приведенную (без циклов, бесплодных и недостижимых символов и -правил)КС-грамматику G(VN,VT,P,S), V = VTVN, в которой:
1. Для каждой упорядоченной пары терминальных и нетерминальных символов выполняется не более чем одно из трех отношений предшествования:
Вi =• Вj ( Bi, Bj V), если и только если правило AxBiBjy P, где AVN, x,yV*;
Вi <• Вj ( Bi, Bj V), если и только если правило AxBiDy P и вывод D*Sjz, где A,DVN, x,y,zV*;
Вi •> Bj ( Bi, Bj V), если и только если правило АхСВjу P и вывод C*zBi или правило AxCDy P и выводы C*zBi и D*Bjw, где A,C,DVN, x,y,z,wV*.
2. Различные правила в грамматике имеют разные правые части (то есть в грамматике не должно быть двух различных правил с одной и той же правой частью).
Отношения =•, <• и •> называют отношениями предшествования для символов. Отношение предшествования единственно для каждой упорядоченной пары символов. При этом между какими-либо двумя символами может и не быть отношения предшествования — это значит, что они не могут находиться рядом ни в одном элементе разбора синтаксически правильной цепочки. Отношения предшествования зависят от порядка, в котором стоят символы, и в этом смысле их нельзя путать со знаками математических операций — они не обладают ни свойством коммутативности, ни свойством ассоциативности. Например, если известно, что Вi •> Bj, то не обязательно выполняется Bj <• Вi (поэтому знаки предшествования иногда помечают специальной точкой: =•, <•, •>).
Для грамматик простого предшествования известны следующие полезные свойства:
всякая грамматика простого предшествования является однозначной;
легко проверить, является или нет произвольная КС-грамматика грамматикой простого предшествования (для этого достаточно проверить рассмотренные выше свойства грамматик простого предшествования или воспользоваться алгоритмом построения матрицы предшествования, который рассмотрен далее).
Как и для многих других классов грамматик, для грамматик простого предшествования не существует алгоритма, который бы мог преобразовать произвольную КС-грамматику в грамматику простого предшествования (или доказать, что преобразование невозможно).
Метод предшествования основан на том факте, что отношения предшествования между двумя соседними символами распознаваемой строки соответствуют трем следующим вариантам:
Bi <• Bi+1, если символ Bi+1 — крайний левый символ некоторой основы (это отношение между символами можно назвать «предшествует основе» или просто «предшествует»);
Вi •> Bi+1, если символ Вi — крайний правый символ некоторой основы (это отношение между символами можно назвать «следует за основой» или просто «следует»);
Вi =• Bi+1, если символы Вi и Bi+1 принадлежат одной основе (это отношение между символами можно назвать «составляют основу»),
Исходя из этих соотношений, выполняется разбор строки для грамматики предшествования.
Суть принципа такого разбора можно пояснить на рис. 12.5. На нем изображена входная цепочка символов в тот момент, когда выполняется свертка цепочки . Символ a является последним символом подцепочки , а символ b — первым символом подцепочки . Тогда, если в грамматике удастся установить непротиворечивые отношения предшествования, то в процессе выполнения разбора по алгоритму «сдвиг-свертка» можно всегда выполнять сдвиг до тех пор, пока между символом на верхушке стека и текущим символом входной цепочки существует отношение <• или =•. А как только между этими символами будет обнаружено отношение •>, так сразу надо выполнять свертку. Причем для выполнения свертки из стека надо выбирать все символы, связанные отношением =•. То, что все различные правила в грамматике предшествования имеют различные правые части, гарантирует непротиворечивость выбора правила при выполнении свертки.
Таким образом, установление непротиворечивых отношений предшествования между символами грамматики в комплексе с несовпадающими правыми частями различных правил дает ответы на все вопросы, которые надо решить для организации работы алгоритма «сдвиг-свертка» без возвратов.
Рис. 12.5. Отношения между символами входной цепочки в грамматике предшествования
На основании отношений предшествования строят матрицу предшествования грамматики. Строки матрицы предшествования помечаются первыми (левыми) символами, столбцы — вторыми (правыми) символами отношений предшествования. В клетки матрицы на пересечении соответствующих столбца и строки помещаются знаки отношений. При этом пустые клетки матрицы говорят о том, что между данными символами нет ни одного отношения предшествования.