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

Решение. Рассмотрим наибольшее начало входа, являющееся K‑началом. Оно представляется в виде конкатенации (последовательного приписывания) нескольких непустых L‑слов и, возможно, одного непустого L‑начала, не являющегося L‑словом. Инвариант цикла: прочитано несколько из них; b <=> (последнее прочитанное является L‑словом).

Сохранение инварианта: если осталось последнее слово, это очевидно; если осталось несколько, то за первым B‑словом (из числа оставшихся) идет символ из Нач(B), и потому это слово —максимальным началом входа, являющееся B‑началом.

На практике при записи грамматики используют сокращения.

Если правила для какого-то нетерминала K имеют вид

K -> L K

K ->

(т.е. K‑слова —это последовательности L‑слов), то этих правил не пишут, а вместо K пишут L в фигурных скобках. Несколько правил с одной левой частью и разными правыми записывают как одно правило, разделяя альтернативные правые части вертикальной чертой.

Например, рассмотренная выше грамматика для <выр> может быть записана так:

<выр> ‑> <слаг> { + <слаг> } <слаг> ‑> <множ> { * <множ> } <множ> ‑> x | ( <выр> )

5.4.8. Написать процедуру, корректно для <выр>, следуя этой грамматике и используя цикл вместо рекурсии, где можно.








Дата добавления: 2015-10-05; просмотров: 658;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.006 сек.