Программа дисциплины «Программирование»
Вид материала | Программа дисциплины |
СодержаниеЗадачи к теме «Формальные языки и грамматики» Задачи по теме «Рекурсия» (и «Формальные языки») Задания по теме «Линейные списки» Создание списков Обработка и преобразование списков |
- Рабочая программа учебной дисциплины (модуля) Системное программирование, 108.12kb.
- Программа дисциплины "Программирование" для направления, 488.76kb.
- Рабочая программа учебной дисциплины (модуля) Объектно-ориентированное программирование, 99.17kb.
- Рабочая учебная программа дисциплины Численные методы и прикладное программирование, 299.02kb.
- Программа дисциплины Математическое программирование Семестры, 10.84kb.
- Рабочая программа учебной дисциплины (модуля) Сетевые технологии и сетевое программирование, 89kb.
- Программа дисциплины Линейное программирование Семестр, 17.93kb.
- Программа учебной дисциплины «Информатика и программирование» Программа дисциплины, 135.24kb.
- Рабочая программа дисциплины теоретическое и прикладное программирование цели и задачи, 146.18kb.
- Программа дисциплины Нелинейное программирование Семестр, 15.39kb.
Задачи к теме «Формальные языки и грамматики»
1. Постройте синтаксическую диаграмму, описывающую идентификаторы, длиной не более четырех символов.
2. Постройте металингвистическую формулу, описывающую целые числа со знаком, включающие не более 5 цифр (используйте металингвистические формулы показателем кратности).
3. Сколько слов в языке, грамматика которого задается правилами:
1) S ::= DBC
2) B ::= aCb
3) C ::= b | 1 | a
4) D ::= a | 0
4. Сколько слов порождает следующая металингвистическая формула:
10 | 110 | 101[1 | 0 | 01 | 000]0
5. Расширим металингвистические формулы показателем кратности: конкатенацию n экземпляров цепочки будем записывать в виде n . Сколько различных слов задает формула
0011304 [1 | 10]n | 0n 1n | [1n | 005]n
6. Две формулы назовем эквивалентными, если они порождают одно и то же множество слов. Являются ли следующие формулы эквивалентными?
F1 = 00 | 11 | {0 | 01}; F2 = {10 | 0}
7. Описать пересечение и объединение множеств цепочек, порождаемых следующими двумя формулами:
F3 = 00 | 111 | {0 | 01}; F4 = {10 | 0}2
Задачи по теме «Рекурсия» (и «Формальные языки»)
1. Нарисовать дерево вызовов процедур при синтаксическом анализе выражения
S+T* (6+d*e)*f–q*h+8
2. Нарисовать дерево вызовов процедур при синтаксическом анализе выражения
(((5))+(((4) – s + d)) + 3)
Приложение 4
Примерный перечень задач по теме «Рекурсивные типы данных»
Задания по теме «Линейные списки»1
Создание списков
- Напишите процедуру создания линейного списка, в информационные поля элементов которого последовательно заносятся номера с 1 до N (N водится с клавиатуры в главной программе). Рассмотрите два варианта процедуры:
- первый включенный в список элемент, имеющий номер 1, оказывается в хвосте списка (последним);
- первый включенный в список элемент, имеющий номер 1, оказывается в голове списка (первым).
- первый включенный в список элемент, имеющий номер 1, оказывается в хвосте списка (последним);
- Напишите рекурсивную процедуру создания линейного списка, в информационные поля элементов которого последовательно заносятся номера с 1 до N (N водится с клавиатуры в главной программе и передается в процедуру в качестве параметра). Рассмотрите два варианта процедуры, как и в предыдущем задании.
- Напишите процедуру создания линейного списка, в информационные поля элементов которого заносятся числа, считываемые из файла (файл может оказаться пустым). Имя файла вводится с клавиатуры в главной программе и передается в процедуру в качестве параметра. Рассмотрите следующие варианты создания списка:
- первый включенный в список элемент оказывается в хвосте списка (последним);
- первый включенный в список элемент оказывается в голове списка (первым);
- элементы включаются в список в порядке возрастания: в информационном поле первого элемента списка должно быть записано минимальное значение, а последнего элемента – максимальное;
- элементы, содержащие отрицательные значения, заносятся всегда в конец списка, а положительные – в начало (в порядке считывания из файла), нулевые – между положительными и отрицательными.
- первый включенный в список элемент оказывается в хвосте списка (последним);
Перепишите все процедуры, написанные при выполнении заданий 1 3, для создания:
- циклического списка и
- двунаправленного списка.
Обработка и преобразование списков
- В программе построен линейный список. Напишите функцию подсчета количества его элементов (рекурсивный и нерекурсивный варианты).
- В программе построен линейный список. Напишите функцию подсчета суммы всех значений, занесенных в информационные поля его элементов (рекурсивный и нерекурсивный варианты).
- В программе построен линейный список. Напишите процедуру подсчета двух сумм: всех положительных и всех отрицательных значений, записанных в информационные поля элементов списка
- В программе построен линейный список. Напишите функцию подсчета разности между суммами всех четных и всех нечетных значений, записанных в информационные поля элементов списка.
- В программе построен линейный список. Напишите процедуру, создающую два новых линейных списка:
- список, включающий все положительные значения из элементов исходного списка, и список, включающий все отрицательные значение из элементов исходного списка; при включении элементов в новые списки, они удаляются из исходного списка; например:
- список, включающий все положительные значения из элементов исходного списка, и список, включающий все отрицательные значение из элементов исходного списка; при включении элементов в новые списки, они удаляются из исходного списка; например:
- список, включающий элементы, ссылающиеся на элементы исходного списка, содержащие в информационных полях положительные значения, и список, включающий элементы, ссылающиеся на элементы исходного списка, содержащие в информационных полях отрицательные значения.
- В программе построен линейный список. Напишите итерационную и рекурсивную процедуры «обращения» списка – создания нового списка, включающего элементы, содержащие те же значения в информационных полях, что и элементы исходного списка, но в обратном порядке (первый элемент исходного списка должен стать последним, второй – предпоследним и т.д., последний – первым).
- В программе построен линейный список. Напишите итерационную и рекурсивную процедуры уничтожения списка.
- В программе построен линейный список. Напишите итерационную и рекурсивную процедуры удаления из списка элементов с повторяющимися в информационных полях значениями.
Перепишите все процедуры, написанные при выполнении заданий 4 7, 10, 11 для обработки:
- циклического списка и
- двунаправленного списка.