
- •Автор: старший преподаватель кафедры Прикладной Математики и Информатики им. Ю.В.Кожевникова Сергей Викторович Сотников.
- •2.3. Общие методы синтаксического анализа 81
- •1. Класс контекстно-свободных языков (V-3.0 28.02.2009)
- •1.1. Свойства кс-языков
- •1.1.1. Теорема Огдена. Лемма о разрастании кс-языков
- •1.2. Приведение кс-грамматик
- •Удаление недостижимых символов;
- •Удаление бесплодных (бесполезных) символов;
- •Удаление цепных правил;
- •1.2.5. Удаление цепных правил
- •1.2.5.1. Алгоритм удаления цепных правил
- •1.3. Нормализация грамматик (Приведение кс-грамматик к нормальной форме)
- •1.3.1.1. Алгоритм преобразования к нормальной форме Хомского
- •1.3.2.1. Устранение левой (правой) рекурсии
- •1.3.2.1.1. Алгоритм устранения левой рекурсии
- •1.3.2.2. Преобразование нелеворекурсивной приведенной кс-грамматики к нормальной форме Грейбах
- •1.3.2.2.1. Алгоритм преобразования нелеворекурсивной приведенной кс-грамматики к нормальной форме Грейбах
- •1.3.2.3. Другой способ преобразования кс-грамматики к нормальной форме Грейбах (Метод Розенкранца)
- •1.3.2.3.1. Алгоритм метода Розенкранца
- •1.4. Автоматы с магазинной памятью (mп-автоматы)
- •1.5. Соотношения между различными мп-автоматами
- •1.5.1. Алгоритм построения мп-автомата по расширенному мп-автомату
- •1.5.2. Алгоритм построения расширенного мп-автомата по мп-автомату
- •1.5.3.1. Алгоритм построения по мп-автомату мп-автомата, допускающего цепочки опустошением магазина
- •1.5.3.1. Алгоритм построения мп-автомата по мп-автомату, допускающего цепочки опустошением магазина
- •1.6. Эквивалентность мп-автоматов и кс-грамматик
- •1.6.1. Алгоритм построения мп-автомата по произвольной кс-грамматике
- •1.6.2. Алгоритм построения расширенного мп-автомата по произвольной кс-грамматике
- •1.6.3. Алгоритм построения кс-грамматики для произвольного мп-автомата
- •1.6.4. Алгоритм построения кс-грамматики для произвольного расширенного мп-автомата
- •2. Методы трансляции
- •2.1. Теория перевода
- •2.1.1. Формализмы, используемые для определения перевода
- •2.1.1.1. Перевод и семантика
- •2.1.1.2. Схемы синтаксически управляемого перевода ( су-схемы)
- •2.1.1.3. Конечные преобразователи
- •2.1.1.4. Преобразователь с магазинной памятью
- •2.1.1.5. Эквивалентность простых су-схем и преобразователей с магазинной памятью
- •2.1.1.5.1. Алгоритм построения мп-преобразователя для простой су-схемы
- •2.1.1.5.2. Алгоритм построения простой су-схемы по мп-преобразователю
- •2.1.2. Лексический анализ
- •2.1.2.1. Непрямой лексический анализ
- •2.1.2.2. Прямой лексический анализ
- •2.1.2.3. Программное моделирование конечных преобразователей
- •2.1.3. Синтаксический анализ
- •2.1.3.1. Определение разбора
- •2.2. Общие методы синтаксического анализа
- •2.2.1. Синтаксический анализ с возвратами
- •2.2.1.1. Алгоритм нисходящего разбора с возвратами
- •2.2.1.2. Проблемы алгоритм нисходящего разбора с возвратами
- •2.2.1.3. Алгоритм восходящего разбора с возвратами
- •Синтаксический анализ с возвратами
- •2.3. Общие методы синтаксического анализа универсальные методы синтаксического анализа. Табличные методы синтаксического анализа Алгоритм Кока-Янгера-Касами
- •Алгоритм разбора Кока-Янгера-Касами
- •Алгоритм нахождения левого разбора по таблице разбора
- •Алгоритм Эрли
- •Алгоритм разбора Эрли
- •Алгоритм построения правого разбора по списку разбора
Алгоритм построения правого разбора по списку разбора
Вход: КС-грамматика
без циклов, правила которой занумерованы
числами от 1 до
,
входная цепочка
и список разбора
для цепочки
.
Выход: Правый разбор цепочки или сообщение об ошибке.
Метод:
Если в списке
нет ситуации вида
,
то
.
Поэтому надо выдать сигнал «ошибка» и
остановиться. В противном случае положить
и выполнить процедуру
.
Процедура
определяется так:
Если - номер правила , то пусть значением переменной будет цепочка, начинающаяся номером , за которым следует предыдущее значение , т.е.
. (Предполагается, что - глобальная переменная)
Если
, то положить
и
.
Если
, вычесть 1 из и из .
Если , найти в
ситуацию
для некоторого
, для которого ситуация
. Затем выполнить процедуру
вычесть 1 из и положить
.
Повторять шаг 3 до тех пор, пока не станет . После этого остановиться.
Пример №1
Задание.
Пусть задана грамматика с правилами
и
– входная цепочка, для которой построен
список разбора
:
Решение.
Так как ситуация вида , то исходная цепочка принадлежит языку . Назначаем и вызываем процедуру
:
,
,
,
,
,
,
.
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
,
, .
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
,
,
.
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
,
,
.
Так как
,
то
,
.
Вернулись из процедуры.
,
.
Вернулись из процедуры.
,
.
Так как
,
то
,
.
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
,
,
.
Так как
,
то
,
.
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
,
,
.
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
,
, .
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
, , .
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
, , .
Так как
,
то
,
.
Вернулись из процедуры.
,
.
Вернулись из процедуры.
, .
Вернулись из процедуры.
, .
Так как
,
то
,
.
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
,
,
.
Так как
,
то
,
где
и
.
Вызываем
:
,
,
,
,
, , .
Так как
,
то
,
.
Вернулись из процедуры.
,
.
Вернулись из процедуры.
, .
Вернулись из процедуры.
, .
Так как
,
то
,
.
Вернулись из процедуры.
,
.
Вернулись из процедуры.
, .
Вернулись из процедуры.
Правый разбор
для входной цепочки
.