Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 13, средняя оценка - 4.92
edward_jonson
160 / 160 / 68
Регистрация: 23.02.2011
Сообщений: 392
#1

Лексический анализатор - C++

10.10.2011, 02:44. Просмотров 2074. Ответов 5
Метки нет (Все метки)

Написал программу, я надеюсь, лексического анализатора для конкретного куска программы. В программе я из текстового файла считывал текст кодируемой программы, потом с помощью функции fgetc() и условных операторов определял лексему, кодировал её целым числом и во второй текстовый файл записывал это число, пробелы и перенос строки учитывался. fgetc() возвращает int-значение символа, поэтому перед тем как делать условные операторы пришлось узнать int-значения всех символов программы. В общем то кроме условных операторов и функции fgetc() я ничего не использовал, можно ли считать вышеописанную программу хотя бы самым примитивным лексическим анализатором?
http://www.cyberforum.ru/cpp-beginners/thread193433.html
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.10.2011, 02:44
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Лексический анализатор (C++):

Лексический анализатор
Доброго времени суток. Сразу скажу, что я не прошу написать какую-либо...

лексический анализатор на С++
Написать лексический анализатор на С++: разделители: , . ; бинарные...

Лексический, синтаксический анализатор c++
Помогите пожалуйста, мне очень сложно понять как это делать( Разработать...

Лексический анализатор текста
Разработать лексический анализатор, который реализует конечный автомат для...

Лексический анализатор - граф перехода КА
Здравствуйте Уважаемые Форумчане. Описание: входной язык содержит логические...

5
Jupiter
Каратель
Эксперт С++
6568 / 3989 / 400
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
10.10.2011, 03:33 #2
Цитата Сообщение от edward_jonson Посмотреть сообщение
В общем то кроме условных операторов и функции fgetc() я ничего не использовал, можно ли считать вышеописанную программу хотя бы самым примитивным лексическим анализатором?
ответ кроется в ответе на вопрос "Можно ли вас считать хорошим студентом?"
PS я не знаю какой вы студент, так же как и не видел вашей программы
PPS не вижу вопросов относительно Си/С++ вообще
0
accept
4833 / 3254 / 454
Регистрация: 10.12.2008
Сообщений: 10,569
10.10.2011, 03:58 #3
Цитата Сообщение от edward_jonson
поэтому перед тем как делать условные операторы пришлось узнать int-значения всех символов программы.
зачем ? используй символы вместо чисел

Цитата Сообщение от edward_jonson
можно ли считать вышеописанную программу хотя бы самым примитивным лексическим анализатором?
если она правильно анализирует разные программы, то можно
0
ValeryLaptev
Эксперт С++
1049 / 828 / 60
Регистрация: 30.04.2011
Сообщений: 1,659
10.10.2011, 10:08 #4
Цитата Сообщение от edward_jonson Посмотреть сообщение
Написал программу, я надеюсь, лексического анализатора для конкретного куска программы. В программе я из текстового файла считывал текст кодируемой программы, потом с помощью функции fgetc() и условных операторов определял лексему, кодировал её целым числом и во второй текстовый файл записывал это число, пробелы и перенос строки учитывался. fgetc() возвращает int-значение символа, поэтому перед тем как делать условные операторы пришлось узнать int-значения всех символов программы. В общем то кроме условных операторов и функции fgetc() я ничего не использовал, можно ли считать вышеописанную программу хотя бы самым примитивным лексическим анализатором?
Без программы - сложно сказать.
Но лексические анализаторы обычно пишутся как конечные автоматы. Если такого слова не знаешь - тогда ответ на твой вопрос: однозначно - нет.
0
Nameless One
Эксперт С++
5785 / 3434 / 351
Регистрация: 08.02.2010
Сообщений: 7,448
10.10.2011, 10:12 #5
Talk is cheap. Show me the code ©
1
silent_1991
Эксперт С++
5007 / 3065 / 270
Регистрация: 11.11.2009
Сообщений: 7,043
Завершенные тесты: 1
10.10.2011, 15:07 #6
Цитата Сообщение от ValeryLaptev Посмотреть сообщение
Если такого слова не знаешь - тогда ответ на твой вопрос: однозначно - нет
Ну почему же? Можно не слышать про конечные автоматы, но тот набор условных переходов, про которые написал ТС, можно в принципе считать переходами из состояния в состояние. С другой стороны, зная теорию построения лексического анализатора на основе конечного детерминированного автомата, всё это можно было бы сделать компактнее (начиная от представления множества состояний enum'ом и свитча по состояниям в цикле и заканчивая набором полиморфных классов, по одному на каждое состояние, и паттерном Интерпретатор).
1
10.10.2011, 15:07
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.10.2011, 15:07
Привет! Вот еще темы с решениями:

Лексический анализатор языка лисп
нужно написать лексический анализатор языка лисп

Лексический анализатор с использованием оператора switch
Здравствуйте! Подскажите, пожалуйста, в чем проблема. По заданию мне надо...

Разработайте лексический анализатор для языка программирования C--
Лексемы, допустимые в языке: letter ::= a | b | ... | z | A | B | ... | Z ...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru