Автор24

Информация о работе

Подробнее о работе

Страница работы

Теория языков программирования и методы трансляции. Лабораторная работа 1-3

  • 45 страниц
  • 2023 год
  • 0 просмотров
  • 0 покупок
Автор работы

user3166365

Автор, испытывающий себя на данной платформе.

700 ₽

Работа будет доступна в твоём личном кабинете после покупки

Гарантия сервиса Автор24

Уникальность не ниже 50%

Фрагменты работ

Входные данные программы состоят из описания КС-грамматики (нетерминальные символы, терминальные символы, целевой символ, правила вывода) и диапазона длин выводимых цепочек (минимальная длина, максимальная длина). Дополнительно может быть введён символ пустой цепочки. По умолчанию, в качестве символа пустой цепочки установлен символ ‘*’.

Терминальные и нетерминальные символы вводятся в поля программы, отделяя отдельные символы друг от друга запятыми. Правила вывода вводятся в отдельном окне программы. При этом программа в левой части правила допускает только ввод нетерминальных символов, а в правой части правила – нетерминальных и терминальных символов, а также символа пустой цепочки.

Результат работы программы представлен на экране в виде упорядоченного в лексикографическом порядке списка выведенных цепочек языка в заданном диапазоне длин.

Основные переменные программы:

VT – терминальные символы.
VN – нетерминальные символы.
Edit4.Text – целевой символ.
P – правила вывода.
Len1 – минимальная длина выводимых цепочек.
Len2 – максимальная длина выводимых цепочек.
Edit5.Text – символ пустой строки.

Основные блоки программы:

Inp – ввод из полей формы терминальных и нетерминальных символов. Дублирующиеся в пределах одного множества символы игнорируются.
InpG – ввод из окна формы правил вывода.
LG – рекурсивная процедура левостороннего вывода цепочек в заданном диапазоне длин.
RG – рекурсивная процедура правостороннего вывода цепочек в заданном диапазоне длин.
Button1Click – запуск левостороннего вывода цепочек по нажатию кнопки «Левосторонний вывод»;
Button2Click – запуск правостороннего вывода цепочек по нажатию кнопки «Правосторонний вывод».


Пусть язык задан контекстно-свободной грамматикой (теоретический материал разделов 1.1–1.4). Написать программу, которая по заданной грамматике будет генерировать ВСЕ цепочки языка в некотором диапазоне длин. Использовать только левосторонний или правосторонний вывод! Диапазон длин генерируемых цепочек должен задаваться пользователем при запуске программы.

Предусмотреть возможность выбора пользователю – использовать заданную в программе грамматику или вводить свою с клавиатуры.

На вход программы подаётся КС-грамматика (терминальный и нетерминальный алфавиты, целевой символ, правила вывода), задаётся диапазон длин цепочек, указывается тип вывода (левосторонний или правосторонний).

Рекомендуется для ввода исходных данных использовать соответствующую форму. При вводе правил грамматики не рекомендуется предоставлять пользователю излишнюю свободу действий, например, удобнее запретить ввод в левой части правил более чем одного нетерминального символа, чем проверять введённые правила на соответствие контекстно-свободному типу.

На выходе должен быть список построенных цепочек. Все цепочки в списке должны быть различны. При получении одинаковых цепочек (разными способами) их следует сохранять в списке выводимых цепочек только в случае выполнения дополнительного задания.

Проверить программу на примерах из лекционного курса и на заданиях из контрольных вопросов к теоретической части.

Какой язык порождается грамматикой G({0},{S,A},{SAAA, AAAA |0}, S)? Правильно ли Ваша программа работает на этом примере? Если нет – доработайте программу.

Грамматика порождает язык L={02n+1| n≥1}. При вводе данного примера программы выдала правильный результат.

4. Разрешает ли Ваша программа использовать в исходной грамматике пустые правила? Если нет – доработайте программу.

Программа разрешает использовать пустые правила.

Форма заказа новой работы

Не подошла эта работа?

Закажи новую работу, сделанную по твоим требованиям

Оставляя свои контактные данные и нажимая «Заказать Лабораторную работу», я соглашаюсь пройти процедуру регистрации на Платформе, принимаю условия Пользовательского соглашения и Политики конфиденциальности в целях заключения соглашения.

Фрагменты работ

Входные данные программы состоят из описания КС-грамматики (нетерминальные символы, терминальные символы, целевой символ, правила вывода) и диапазона длин выводимых цепочек (минимальная длина, максимальная длина). Дополнительно может быть введён символ пустой цепочки. По умолчанию, в качестве символа пустой цепочки установлен символ ‘*’.

Терминальные и нетерминальные символы вводятся в поля программы, отделяя отдельные символы друг от друга запятыми. Правила вывода вводятся в отдельном окне программы. При этом программа в левой части правила допускает только ввод нетерминальных символов, а в правой части правила – нетерминальных и терминальных символов, а также символа пустой цепочки.

Результат работы программы представлен на экране в виде упорядоченного в лексикографическом порядке списка выведенных цепочек языка в заданном диапазоне длин.

Основные переменные программы:

VT – терминальные символы.
VN – нетерминальные символы.
Edit4.Text – целевой символ.
P – правила вывода.
Len1 – минимальная длина выводимых цепочек.
Len2 – максимальная длина выводимых цепочек.
Edit5.Text – символ пустой строки.

Основные блоки программы:

Inp – ввод из полей формы терминальных и нетерминальных символов. Дублирующиеся в пределах одного множества символы игнорируются.
InpG – ввод из окна формы правил вывода.
LG – рекурсивная процедура левостороннего вывода цепочек в заданном диапазоне длин.
RG – рекурсивная процедура правостороннего вывода цепочек в заданном диапазоне длин.
Button1Click – запуск левостороннего вывода цепочек по нажатию кнопки «Левосторонний вывод»;
Button2Click – запуск правостороннего вывода цепочек по нажатию кнопки «Правосторонний вывод».


Пусть язык задан контекстно-свободной грамматикой (теоретический материал разделов 1.1–1.4). Написать программу, которая по заданной грамматике будет генерировать ВСЕ цепочки языка в некотором диапазоне длин. Использовать только левосторонний или правосторонний вывод! Диапазон длин генерируемых цепочек должен задаваться пользователем при запуске программы.

Предусмотреть возможность выбора пользователю – использовать заданную в программе грамматику или вводить свою с клавиатуры.

На вход программы подаётся КС-грамматика (терминальный и нетерминальный алфавиты, целевой символ, правила вывода), задаётся диапазон длин цепочек, указывается тип вывода (левосторонний или правосторонний).

Рекомендуется для ввода исходных данных использовать соответствующую форму. При вводе правил грамматики не рекомендуется предоставлять пользователю излишнюю свободу действий, например, удобнее запретить ввод в левой части правил более чем одного нетерминального символа, чем проверять введённые правила на соответствие контекстно-свободному типу.

На выходе должен быть список построенных цепочек. Все цепочки в списке должны быть различны. При получении одинаковых цепочек (разными способами) их следует сохранять в списке выводимых цепочек только в случае выполнения дополнительного задания.

Проверить программу на примерах из лекционного курса и на заданиях из контрольных вопросов к теоретической части.

Какой язык порождается грамматикой G({0},{S,A},{SAAA, AAAA |0}, S)? Правильно ли Ваша программа работает на этом примере? Если нет – доработайте программу.

Грамматика порождает язык L={02n+1| n≥1}. При вводе данного примера программы выдала правильный результат.

4. Разрешает ли Ваша программа использовать в исходной грамматике пустые правила? Если нет – доработайте программу.

Программа разрешает использовать пустые правила.

Купить эту работу

Теория языков программирования и методы трансляции. Лабораторная работа 1-3

700 ₽

или заказать новую

Лучшие эксперты сервиса ждут твоего задания

от 200 ₽

Гарантии Автор24

Изображения работ

Страница работы
Страница работы
Страница работы

Понравилась эта работа?

или

7 февраля 2023 заказчик разместил работу

Выбранный эксперт:

Автор работы
user3166365
4.5
Автор, испытывающий себя на данной платформе.
Купить эту работу vs Заказать новую
0 раз Куплено Выполняется индивидуально
Не менее 40%
Исполнитель, загружая работу в «Банк готовых работ» подтверждает, что уровень оригинальности работы составляет не менее 40%
Уникальность Выполняется индивидуально
Сразу в личном кабинете Доступность Срок 1—4 дня
700 ₽ Цена от 200 ₽

5 Похожих работ

Лабораторная работа

Лабораторные работы из учебника "Сборник лабораторных работ" П. Чистов и А. Мальгинова

Уникальность: от 40%
Доступность: сразу
1500 ₽
Лабораторная работа

Использование одномерных и двумерных массивов

Уникальность: от 40%
Доступность: сразу
100 ₽
Лабораторная работа

Дискретная математика. Системы счисления.

Уникальность: от 40%
Доступность: сразу
100 ₽
Лабораторная работа

Дискретная математика. Множества и работа с ними.

Уникальность: от 40%
Доступность: сразу
100 ₽
Лабораторная работа

Дискретная математика. Графы. Основные понятия.

Уникальность: от 40%
Доступность: сразу
100 ₽

Отзывы студентов

Отзыв pocya об авторе user3166365 2016-10-09
Лабораторная работа

Автор очень ответственно и профессионально подходит к выполнению заказов. Большое спасибо!

Общая оценка 5
Отзыв Алексей Ерасов об авторе user3166365 2016-11-13
Лабораторная работа

Автор помог в сжатые сроки, а также прокомментировал все свои действия

Общая оценка 5
Отзыв Aleksandr2772 об авторе user3166365 2018-12-27
Лабораторная работа

Все верно и в срок

Общая оценка 5
Отзыв style2off1988 об авторе user3166365 2016-01-02
Лабораторная работа

Все отлично. Автора рекомендую.

Общая оценка 5

другие учебные работы по предмету

Готовая работа

Адаптация программных систем на основе функционального подхода

Уникальность: от 40%
Доступность: сразу
150 ₽
Готовая работа

Экспертная кибернетическая идентификация

Уникальность: от 40%
Доступность: сразу
140 ₽
Готовая работа

Моделирование процессов возникновения и развития чрезвычайных ситуаций

Уникальность: от 40%
Доступность: сразу
300 ₽
Готовая работа

Моя будущая профессия – программист

Уникальность: от 40%
Доступность: сразу
875 ₽
Готовая работа

Исторические предпосылки возникновения интеллектуальных компьютерных систем

Уникальность: от 40%
Доступность: сразу
150 ₽
Готовая работа

Электронная ведомость учета часов, пропущенных студентами (Excel+VBA)

Уникальность: от 40%
Доступность: сразу
2000 ₽
Готовая работа

Разработка системы сбора и анализа информации о новой коронавирусной инфекции (Python Django)

Уникальность: от 40%
Доступность: сразу
2000 ₽
Готовая работа

Автоматизация комплекса задач складского предприятия с использованием 1С

Уникальность: от 40%
Доступность: сразу
2200 ₽
Готовая работа

WEB-приложение для школы. Предмет исследования – учет успеваемости в школе.

Уникальность: от 40%
Доступность: сразу
3500 ₽
Готовая работа

программный продукт в виде компьютерной обучающей игры на движке Unity

Уникальность: от 40%
Доступность: сразу
5000 ₽
Готовая работа

Разработка web-информационной системы отдела кадров

Уникальность: от 40%
Доступность: сразу
1500 ₽
Готовая работа

Системы идентификации личности по лицу

Уникальность: от 40%
Доступность: сразу
3000 ₽