
- •Белорусский национальный технический университет
- •Функциональное и логическое программирование
- •Лабораторная работа 1. Основы работы с Visual Prolog в режиме Test Goal.
- •Лабораторная работа 2. Составление простейшей пролог-программы.
- •Лабораторная работа 3. Формирование правил.
- •2. Краткие справочные данные.
- •3. Содержание задания по лабораторной работе.
- •4. Содержание отчета.
- •Лабораторная работа 4. Рекурсия.
- •2. Краткие справочные данные.
- •3. Содержание задания по лабораторной работе.
- •4. Задачи на рекурсию.
- •5. Содержание отчета.
- •Лабораторная работа 5. Использование отсечения в пролог-программах.
- •2. Краткие справочные данные.
- •Содержание задания по лабораторной работе.
- •4. Содержание отчета.
- •Лабораторная работа 6. Работа со списками.
- •5. Содержание отчета.
- •Лабораторная работа 7. Работа со строками.
- •Лабораторная работа 8. Использование составных объектов.
- •[Член_семьи(“Инна”,”Иванова”,дата(20,март,1971), работа(студент,45)),
- •Лабораторная работа 9. Работа с файлами.
- •Лабораторная работа 10. Построение меню.
- •Лабораторная работа 11. Динамические базы данных.
- •Лабораторная работа 12. Внешние базы данных.
- •Содержание задания по лабораторной работе.
- •Содержание отчета:
- •Содержание задания по лабораторной работе.
- •Содержание отчета:
- •Лабораторная работа 14. Рекурсивное объявление доменов.
- •Краткие справочные данные.
- •Текст Пролог-программы
- •Содержание задания по лабораторной работе.
- •Содержание отчета:
- •Лабораторная работа 15. Основы работы в среде визуального программирования visual prolog.
- •Содержание задания по лабораторной работе.
- •Лабораторная работа 16. Система программирования mulisp.
- •Содержание задания по лабораторной работе.
- •Лабораторная работа 17. Определение функций в lisp.
- •2. Краткие справочные данные.
- •Представление данных в Лисп.
- •Содержание задания по лабораторной работе.
- •Литература
- •Приложение
- •Содержание
Содержание задания по лабораторной работе.
Определить функцию, вычисляющую x + y – x*y.
Определить функции (null x), (caddr x) и (list x1 x2 x3) с помощью базовых функций (использовать имена null1, caddr1, list1, чтобы не переопределять одноименные встроенные функции Лисп).
Определить логическую функцию ИЛИ (OR) (имя OR не использовать).
Определить логическую функцию НЕ (NOT) (имя NOT не использовать).
Определить N-ое число Фибоначчи.
Подсчитать количество элементов списка.
Все элементы списка увеличить на заданное число.
Выделить последний элемент списка.
Добавить заданный элемент в конец списка.
Удалить из списка последний элемент.
Удалить из списка первое вхождение заданного элемента на верхнем уровне.
Удалить из списка все вхождения заданного элемента на верхнем уровне
Удалить из списка каждый второй элемент.
Определить среднее арифметическое элементов списка.
Подсчитать количество отрицательных элементов списка.
Определить минимальный элемент целочисленного списка (не используя встроенную функцию min).
Заменить в списке все элементы со значением X на значение Y.
Удалить начало списка до заданного элемента X (включительно).
Получить новый отсортированный список путем вставки заданного элемента в исходный отсортированный в порядке возрастания элементов список.
Определить функцию, разбивающую список (a b c d …) на пары ((a b) (c d) … ).
Определить функцию, которая, чередуя элементы списков (a b …) и (1 2 …), образует новый список (a 1 b 2 …).
Определить функцию (первый-совпадающий x y), которая возвращает первый элемент, входящий в оба списка x и y, в противном случае nil.
Проверить, является ли список множеством, т.е. входит ли каждый элемент в список лишь один раз.
Преобразовать список в множество, т.е. удалить из списка повторяющиеся элементы.
Определить предикат Равенство-множеств, проверяющий совпадение двух множеств (независимо от порядка следования элементов).
Определить предикат Подмножество, проверяющий, является ли одно множество подмножеством другого.
Определить функцию Пересечение, определяющую общие для дух множеств элементы.
Определить предикат Непересекающиеся, проверяющий, что два множества не имеют общих элементов.
Определить функцию Объединение, формирующую объединение двух множеств.
Определить функцию Разность, формирующую разность двух множеств, т.е. удаляющую из первого множества все общие со вторым множеством элементы.
4. Содержание отчета: цель работы, постановка задачи, тексты определяемых функций, результаты тестирования функций, выводы.
Замечания:
- при определении функций использовать только следующие примитивы Lisp: car, cdr, cons, atom, eq, quote, plusp, minusp, zerop, set, setq, equal, null, list, математические функции, функции сравнения чисел и логические функции and , or, not;
- в заданиях 3.22 – 3.30 использовать вспомогательную функцию, проверящую принадлежность заданного элемента списку;
- для формирования отчета использовать редактор muLisp.
Контрольные вопросы:
Какие объекты относятся к символьным выражениям Lisp ?
Какие объекты относятся к атомам Lisp ?
Что означает атом NIL ?
Что такое конс ?
Префиксная форма записи выражений в Lisp.
Какие функции в Lisp называются предикатами ?
Управляющие структуры Lisp для последовательных вычислений.
Управляющие структуры Lisp для разветвления вычислений.
Основной механизм программирования циклических вычислений.
Определение функций в Lisp.
Можно ли в качестве имени определяемой функции взять имя стандартной функции Lisp.
Принципиальное отличие восходящей рекурсии от нисходящей рекурсии.
Вспомогательные (промежуточные) функции.
Суть двумерной рекурсии.