- •3 Лабораторная работа №2 (программирование разветвлённых алгоритмов) 12
- •4 Лабораторная работа №3 (программирование простых циклических алгоритмов) 16
- •7 Решение индивидуального задания 28
- •Постановка задачи
- •Лабораторная работа №1 (программирование линейных алгоритмов)
- •Реализация на языке lisp
- •Реализация на языке Prolog
- •Лабораторная работа №2 (программирование разветвлённых алгоритмов)
- •Реализация на языке lisp
- •Реализация на языке Prolog
- •Лабораторная работа №3 (программирование простых циклических алгоритмов)
- •Реализация на языке lisp
- •Реализация на языке Prolog
- •Лабораторная работа №4 (программирование с использованием одномерных массивов)
- •Реализация на языке lisp
- •Реализация на языке Prolog
- •Лабораторная работа №5 (программирование с использованием многомерных массивов)
- •Реализация на языке lisp
- •Реализация на языке Prolog
- •Решение индивидуального задания
- •Реализация на языке lisp
- •Функция podspvsp
- •Функция evropa
- •Функция opa
- •7.1.5 Функция v1spisok
- •7.1.6 Функция get1
- •7.1.7 Функция get22
- •7.1.8 Функция getpolug
- •7.1.9 Функция 1polniz
- •7.1.10 Функция 2polniz
- •7.1.11 Функция 2polverh
- •7.1.12 Функция 1polverh
- •7.1.13 Функция getdiag
- •7.1.14 Функция getdown
- •7.1.15 Функция getup
- •Функция 1hlpod
- •Функция 2hlpod
- •7.1.18 Функция revpod
- •7.1.19 Функция deletefirst
- •7.1.20 Функция get1half
- •7.1.21 Функция get2half
- •7.1.22 Функция neto
- •7.1.23 Функция dl
- •7.1.24 Функция revers
- •7.1.25 Функция gl
- •7.1.26 Полный текст программы
- •Реализация на языке Prolog
- •Функция ygolki
- •Функция app
- •Функция main
- •7.2.4 Функция opp
- •7.2.5 Функция verhyg
- •7.2.6 Функция nizyg
- •7.2.7 Функция diag
- •Функция fpolpodsp
- •Функция npolpodsp
- •7.2.10 Функция reveverspodsp
- •7.2.11 Функция delall
- •7.2.12 Функция fpol
- •7.2.13 Функция npoll
- •7.2.14 Функция npol
- •7.2.15 Функция dl
- •7.2.16 Функция revers
- •7.2.17 Функция getlalst
- •7.2.18 Полный текст программы
-
Решение индивидуального задания
-
Реализация на языке lisp
-
Функция baba
-
-
7.1.1.1 Спецификация
Функция должна находить верхние и нижние «уголки», соединять их соответственно рисунку и формировать конечный последовательный список чисел.
7.1.1.2 Структура входных данных
Структурой входных данных в данной функции является список (списков чисел). Примеры записи на языке LISP приведены на рисунке 7.1
((1)) ((1 2)(3 4)) ((1 2 3)(4 5 6)(7 8 9)) |
Рисунок 7.1
7.1.1.3 Структура выходных данных
Структурой выходных данных в данной функции является список (чисел). Примеры записи на языке LISP приведены на рисунке 7.2.
(1) (1 2 3 4) |
Рисунок 7.2
7.1.1.4 Функциональные тесты
Функциональные тесты для функции baba приведены в таблице 7.1
Таблица 7.1
Проверяемая ситуация |
Вызов функции со входным значением |
Предполагаемый результат |
Пустой список |
(baba ‘()) |
nil |
Список списков чисел |
(baba ‘((1))) (baba ‘((2 1)(4 3))) (baba ‘((7 1 3)(4 6 2)(9 3 8))) |
(1) (1 2 3 4) (1 2 3 4 5 6 7 8 9) |
7.1.1.5 Словесное описание результата применения функции
Возвращается список чисел, расположенных в заданном порядке в матрице.
-
Текст программы
Текст программы представлен на рисунке 7.4.
(defun baba (lst) (podspvsp(opa(v1spisok(get11 lst) (get22 lst))))) |
Рисунок 7.4
-
Функция podspvsp
7.1.2.1 Спецификация
Функция должна формировать из списка списков чисел единый список.
-
Структура входных данных
Структурой входных данных в данной функции является список. Примеры записи на языке LISP приведены на рисунке 7.5
((3) (4) (2) (1)) ((7) (9) (6) (8 4) (1 5) (3) nil (2)) |
Рисунок 7.5
-
Структура выходных данных
Структурой выходных данных в данной функции является список (чисел). Примеры записи на языке LISP приведены на рисунке 7.6
(3 4 2 1) (7 9 6 8 4 1 5 3 2) |
Рисунок 7.6
-
Функциональные тесты
Функциональные тесты для функции podspvsp приведены в таблице 7.2
Таблица 7.2
Проверяемая ситуация |
Вызов функции со входным значением |
Предполагаемый результат |
Пустой список |
(podspvsp ‘()) |
nil |
Список списков чисел |
(podspvsp ‘((1))) (podspvsp ‘((3) (4) (2) (1))) (podspvsp ‘((7) (9) (6) (8 4) (1 5) (3) nil (2))) |
(1) (3 4 2 1) (7 9 6 8 4 1 5 3 2) |
-
Словесное описание результата применения функции
Из списка списков убираются все скобки и лишний элемент nil, оставшийся после удаления скобок от последнего списка, и в итоге формируется единый список чисел.
-
Текст программы
Текст программы представлен на рисунке 7.7
(defun podspvsp(lst) (cond ((null lst)lst) (t(v1spisok(car lst) (podspvsp(cdr lst)))))) |
Рисунок 8.7