Теория языков программирования и методы трансляции. Курсовая работа. 9-й вариант + Доп.задание к курсовой работе

Состав работы

material.view.file_icon
material.view.file_icon
material.view.file_icon 9.doc
material.view.file_icon
material.view.file_icon Project1.cfg
material.view.file_icon Project1.dof
material.view.file_icon Project1.dpr
material.view.file_icon Project1.exe
material.view.file_icon Project1.res
material.view.file_icon Project1.~dpr
material.view.file_icon result.txt
material.view.file_icon Unit1.dcu
material.view.file_icon Unit1.ddp
material.view.file_icon Unit1.dfm
material.view.file_icon Unit1.pas
material.view.file_icon Unit1.~dfm
material.view.file_icon Unit1.~pas
material.view.file_icon Unit2.dcu
material.view.file_icon Unit2.dfm
material.view.file_icon Unit2.pas
material.view.file_icon Unit2.~dfm
material.view.file_icon
Работа представляет собой rar архив с файлами (распаковать онлайн), которые открываются в программах:
  • Microsoft Word
  • Программа для просмотра текстовых файлов

Описание

Задание

Вариант 9
Написать программу для автоматического построения регулярного выражения (РВ) по словесному описанию языка.
Вход программы: алфавит языка, обязательные начальная и конечная подцепочки, кратность длины всех цепочек языка, 2 числа – диапазон длин для генерации цепочек.
Выход: построенное регулярное выражение, результат генерации цепочек.
Подробно:
Язык задан своим алфавитом, обязательной начальной и конечной подцепочками и указанием кратности длины всех цепочек языка. В заданных подцепочках не должно находиться символов, не содержащихся в алфавите. В крайнем случае они (одна или обе) могут быть и пустыми. Особый случай – это пересечение заданных цепочек по одному или нескольким символам, в том числе и полное их совпадение. Кратность длины цепочек задается любым натуральным числом. Кратность, равная единице, равносильна отсутствию ограничений на длину цепочек.
Программа должна:
1. по предложенному описанию регулярного языка строить РВ, задающее этот язык, в том виде, как было рассмотрено в теории, раздел 2.1.1;
2. с помощью построенного РВ генерировать все цепочки языка в заданном пользователем диапазоне длин.
При генерации цепочек языка по РВ можно использовать любые структуры и алгоритмы, в том числе и прямой перебор.
Рассмотрим пример построения регулярного выражения.
Задан язык: алфавит {a,b,c}, обязательная начальная цепочка ‘саа’, конечная цепочка ‘aab’, длина цепочек кратна 2. Анализируем задание: язык будет состоять из цепочек чётной длины, начинающихся с цепочки ‘cаа’ и заканчивающихся на ‘aab’, например {сaab, сaaааb, caaасааb, сaabсaab, …}.
Для начала определим минимально возможную цепочку этого языка. Это ‘сaab’ – она получается при максимальном пересечении начальной и конечной цепочек, удовлетворяет всем условиям и является при этом самой короткой. Удлинить её можно путём уменьшения области пересечения начальной и конечной цепочек. Следующая по длине цепочка могла бы быть ‘сaаab’ (пересечение по одному символу), но она не удовлетворяет условию чётности длины. А вот ещё следующая цепочка – ‘сaaааb’ – получена простым соединением начальной и конечной цепочек. Это основа нашего РВ. Её можно удлинять, помещая между начальной и конечной цепочками некоторое количество символов алфавита, причём для сохранения чётности длины это количество тоже должно быть чётным. Для генерации любого количества пар символов используется итерация, а выбор одного из нескольких символов записывается в виде суммы.
Итоговое регулярное выражение будет иметь вид: саа((а+b+c)(a+b+c))*aab+caaaab.
Если в этом же задании изменить кратность длины на единицу, то итоговое РВ изменится таким образом: добавлять можно будет не пары символов, а по одному символу любое количество раз, и пересечения цепочек будут использованы все. Итоговое регулярное выражение будет иметь вид: саа(a+b+c)*aab+caaab +caaaab.

Доп.задание:

Программа чужая. Для получения положительной оценки придется выполнить дополнительное задание. Добавьте генерацию цепочек по введенному пользователем РВ.

Результат доработки:

Для выполнения дополнительного задания на панель программы добавлена редактируемая область для строки РВ. Данная область используется следующим образом. При построении РВ в эту область выводится результат, т.е. построенное РВ. При генерации цепочек из этой области читается строка с РВ. В любой момент времени можно изменить содержимое области с РВ с клавиатуры.
В строке с РВ все символы, не совпадающие с символами круглых скобок и символами операций выбора и итерации, считаются символами алфавита языка. При этом символы алфавита языка, введенные в другом поле на панели программы игнорируются. Таким образом, при измененной с клавиатуры строке с РВ, т.е. отличной от той, которая была получена при построении РВ по входным данным, алфавит языка при генерации цепочек может быть другой.
Вывод на экран сгенерированных по РВ цепочек оставлен прежним.


Дополнительное задание в отдельном архиве - Добавьте генерацию цепочек по введенному пользователем РВ.

Дополнительная информация

работа сдавалась в ноябре 2017, Бах О.А.

Зачтена после доработки:
"Программа чужая. Для получения положительной оценки придется выполнить дополнительное задание. Добавьте генерацию цепочек по введенному пользователем РВ".

В архиве отдельно отправленная изначально курсовая и в архиве "доработано" программа и отчет с изменениями.

Внимание! В работе и программе указано ФИО автора.
Теория языков программирования и методы трансляции
Лабораторные работы основаны на лекционном материале; каждая выполняется после изучения соответствующего теоретического раздела. До выполнения лабораторной работы нужно внимательно разобраться с примерами, ответить на контрольные вопросы изученного теоретического раздела, а также решить задачи, предлагаемые в составе контрольных вопросов. Каждая работа снабжена методическими указаниями, сопровождающими текст задания. Рекомендуется внимательно читать задание и выполнять работу в строгом соответс
User Илья272 : 5 ноября 2023
1300 руб.
Теория языков программирования и методы трансляции
Билет No1 1) Классификация грамматик и языков по Хомскому. Проиллюстрировать на примерах (примеры должны быть свои). 2) Нисходящий распознаватель языков с возвратами. Алгоритм распознавателя с подбором альтернатив. Проиллюстрировать на примере (пример должен быть свой). 3) Построить детерминированный автомат с магазинной памятью P (с опустошением стека), допускающий язык L(P) = {a n b n c 2k k > 0, n 0}. Построить КС-грамматику для задания этого же языка.
User piligrim-24 : 11 апреля 2012
50 руб.
Теория языков программирования и методы трансляции
Лабораторная работа № 3 По дисциплине «Теория языков программирования и методы трансляции» Моделирование работы МПА Пусть контекстно-свободный язык задаётся детерминированным автоматом с магазинной памятью – ДМПА (теоретический материал раздела 3.1). Написать программу, которая будет проверять для вводимой цепочки, принадлежит ли она заданному КС-языку. В случае отрицательного ответа необходимо давать пояснение, по какой причине цепочка не принадлежит языку (аналогично лаб. раб №2) Исходный авт
User piligrim-24 : 3 марта 2012
50 руб.
Курсовая работа по дисциплине Теория языков программирования и методы трансляции
Написать программу для автоматического построения детерминированного конечного автомата (ДКА) по словесному описанию языка. Вход программы: алфавит языка, обязательная конечная подцепочка, цепочки для распознавания. Выход: построенный ДКА (все 5 элементов), результат проверки цепочек. Подробно: Язык задан своим алфавитом, обязательной конечной цепочкой всех цепочек языка. В конечной цепочке не должно находиться символов, не содержащихся в алфавите. В край
User Некто : 16 сентября 2018
200 руб.
Теория языков программирования и методы трансляции. Курсовая работа. Вариант 13.
Написать программу, которая по заданной регулярной грамматике (грамматика может быть НЕ автоматного вида! ЛЛ или ПЛ) построит эквивалентный ДКА (представление функции переходов в виде таблицы). Программа должна сгенерировать по исходной грамматике несколько цепочек в заданном диапазоне длин и проверить их допустимость построенным автоматом. Процессы построения цепочек и проверки их выводимости отображать на экране (по требованию).
User Сергей442 : 13 ноября 2023
2500 руб.
Теория языков программирования и методы трансляции. Курсовая работа. Вариант 13.
Теория языков программирования и методы трансляции курсовая работа вариант 4
Вариант 4 Написать программу для автоматического построения детерминированного конечного автомата (ДКА), эквивалентного заданной регулярной грамматике. Вход программы: терминальный и нетерминальный алфавиты грамматики, целевой символ, правила грамматики, цепочки для распознавания. Выход: построенный ДКА (все 5 элементов), результат проверки цепочек. Подробно: Язык задан регулярной грамматикой, причём она может быть не автоматного вида. При написании программы разработчику разрешается выбрать оди
User svladislav987 : 29 августа 2023
500 руб.
Теория языков программирования и методы трансляции. Курсовая работа. Вариант 19.
Написать программу, которая для языка, заданного контекстно-свободной грамматикой в требуемой форме (проверить корректность задания и при отрицательном результате выдать соответствующее сообщение), построит детерминированный распознаватель с магазинной памятью, используя алгоритм восходящего анализа с возвратами («сдвиг-свертка»). Программа должна сгенерировать по исходной грамматике несколько цепочек в указанном диапазоне длин и проверить их допустимость построенным ДМПА. Процессы построения ц
User LowCost : 8 января 2021
499 руб.
promo
Теория языков программирования и методы трансляции. Курсовая работа. Вариант 10.
Вариант 10 Написать программу для автоматического построения регулярной грамматики (леволинейной или праволинейной) по словесному описанию языка. Вход программы: алфавит языка, обязательная конечная подцепочка, кратность длины всех цепочек языка, тип грамматики (ЛЛ либо ПЛ), 2 числа – диапазон длин для генерации цепочек. Выход: построенная грамматика (все 4 элемента), результат генерации цепочек. Подробно: Язык задан своим алфавитом, обязательной конечной подцепочкой, которая должна присутствова
User Bodibilder : 3 июля 2019
200 руб.
Экзамен по предмету: Аудиовизуальные средства мультимедиа. Билет 22
Билет №22 1. Объективные и субъективные характеристики цвета. 2. Синтез звука на основе частотной модуляции. 3. Диски DVD-R, DVD-RAM.
User domicelia : 28 февраля 2012
200 руб.
Чрезвычайные ситуации военного времени
Ядерное оружие (ЯО) – оружие массового поражения взрывного действия, основанное на использовании внутриядерной энергии, выделяющейся при цепных реакциях деления тяжелых ядер некоторых изотопов урана и плутония или при термоядерных реакциях синтеза легких ядер – изотопов водорода (дейтерия и трития) в более тяжелые, например ядра изотопов гелия. Это оружие включает различные ядерные боеприпасы (боевые части ракет и торпед, авиационные и глубинные бомбы, артиллерийские снаряды и мины, снаряженные
User Lokard : 9 марта 2014
15 руб.
Тележка гидравлическая для перемещения агрегатов
В архиве 3 чертежа в компасе формата А1(общий вид, механизм подъема, ремонтный чертеж штока) и пояснительная записка. Спецификация присутствует. ОГЛАВЛЕНИЕ Введение……………………………………………..…………………………… 4 1 Анализ конструкций подъемно-транспортного оборудования..………..….. 1.1 Классификация подъемно-транспортного оборудования ..…………... 1.2 Характеристика и анализ конструкций подъемно-транспортного оборудования …………………………………………………….……… 5 2 Устройство, принцип действия и техническая характеристика тележки
User vjycnh : 29 января 2016
300 руб.
Тележка гидравлическая для перемещения агрегатов
Кейс по УП
СИТУАЦИЯ № 10 Во время маневра тепловоза на внутризаводских путях машинист Г. не убедился, что путь свободен, и тронулся с места. Однако в это время путь пересекал груженный газовыми баллонами автомобиль. В результате столкновения водитель автомобиля погиб. Дайте юридическую оценку действиям Г. СИТУАЦИЯ № 11 М., управляя личным автомобилем "Мерседес", проявил невнимательность и сбил пешехода, который от полученных повреждений скончался в больнице. Следователь К. в отношении М. возбудил уголовно
User qwerty123432 : 30 января 2023
109 руб.
Кейс по УП
up Наверх