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

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

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

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

Лексический анализатор
Получил задание. Ранее с++ не изучал. Если найдутся добрые люди, которые могут...

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

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

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

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

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

Цитата Сообщение от edward_jonson
можно ли считать вышеописанную программу хотя бы самым примитивным лексическим анализатором?
если она правильно анализирует разные программы, то можно
0
ValeryLaptev
Эксперт С++
1050 / 829 / 60
Регистрация: 30.04.2011
Сообщений: 1,659
10.10.2011, 10:08 4
Цитата Сообщение от edward_jonson Посмотреть сообщение
Написал программу, я надеюсь, лексического анализатора для конкретного куска программы. В программе я из текстового файла считывал текст кодируемой программы, потом с помощью функции fgetc() и условных операторов определял лексему, кодировал её целым числом и во второй текстовый файл записывал это число, пробелы и перенос строки учитывался. fgetc() возвращает int-значение символа, поэтому перед тем как делать условные операторы пришлось узнать int-значения всех символов программы. В общем то кроме условных операторов и функции fgetc() я ничего не использовал, можно ли считать вышеописанную программу хотя бы самым примитивным лексическим анализатором?
Без программы - сложно сказать.
Но лексические анализаторы обычно пишутся как конечные автоматы. Если такого слова не знаешь - тогда ответ на твой вопрос: однозначно - нет.
0
Nameless One
Эксперт С++
5786 / 3435 / 351
Регистрация: 08.02.2010
Сообщений: 7,448
10.10.2011, 10:12 5
Talk is cheap. Show me the code ©
1
silent_1991
Эксперт С++
5009 / 3069 / 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
Здравствуйте! Подскажите, пожалуйста, в чем проблема. По заданию мне надо...


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

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

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