![]() |
Модераторы: Poseidon, Snowy, bems, MetalFan |
![]() ![]() ![]() |
|
Petr1993 |
|
|||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 4.1.2013 Репутация: нет Всего: нет |
Как можно рекурсивно реализовать синтаксический анализатор скобок
<скобки> ::= {<квадр> |<кругл>} <кругл> ::= {<квадр><квадр>| -} <квадр> ::= {<кругл><кругл>| +} |
|||
|
||||
bems |
|
|||
![]() Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Комодератор Сообщений: 3400 Регистрация: 5.1.2006 Репутация: 31 Всего: 88 |
прямо в лоб и пиши.
вычитываешь символ, если он является открывающей скобкой, то рекурсивно вызываешь ту же функцию разбора, которая вычитает уже следующий символ. после рукурсивного вызова проверяешь что оставшийся символ это закрывающая скобка того же типа. если это не так, то сообщаешь об ошибке. только продукции нужно переформулировать так, чтобы небыло левой рекурсии, иначе это никогда не закончится в том виде что ты привел она есть, это не годится ну и если кроме скобок и знаков + и - будут еще числа либо идентификаторы длиной больше одного символа, то может оказаться гораздо удобней сделать перед этим еще лексический анализ Это сообщение отредактировал(а) bems - 6.1.2013, 21:20 -------------------- Обижено школьников: 8 |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Delphi: Общие вопросы" | |
|
Запрещается! 1. Публиковать ссылки на вскрытые компоненты 2. Обсуждать взлом компонентов и делиться вскрытыми компонентами
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, MetalFan, bems, Poseidon, Rrader. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Delphi: Общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |