Модераторы: Poseidon, Snowy, bems, MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как написать рекурсивный синтаксический анализатор 
:(
    Опции темы
Petr1993
Дата 4.1.2013, 16:00 (ссылка)    | (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 4.1.2013

Репутация: нет
Всего: нет



Как можно рекурсивно реализовать синтаксический анализатор скобок

 <скобки> ::= {<квадр> |<кругл>}
 <кругл> ::= {<квадр><квадр>| -}
 <квадр> ::= {<кругл><кругл>| +}
PM MAIL   Вверх
bems
Дата 6.1.2013, 21:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 3400
Регистрация: 5.1.2006

Репутация: 31
Всего: 88



прямо в лоб и пиши. 
вычитываешь символ, если он является открывающей скобкой, то рекурсивно вызываешь ту же функцию разбора, которая вычитает уже следующий символ. после рукурсивного вызова проверяешь что оставшийся символ это закрывающая скобка того же типа. если это не так, то сообщаешь об ошибке.
только продукции нужно переформулировать так, чтобы небыло левой рекурсии, иначе это никогда не закончится
в том виде что ты привел она есть, это не годится
ну и если кроме скобок и знаков + и - будут еще числа либо идентификаторы длиной больше одного символа, то может оказаться гораздо удобней сделать перед этим еще лексический анализ


Это сообщение отредактировал(а) bems - 6.1.2013, 21:20


--------------------
Обижено школьников: 8
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Общие вопросы"
SnowyMetalFan
bemsPoseidon
Rrader

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, MetalFan, bems, Poseidon, Rrader.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0921 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.