Функциональное и логическое программирование. вариант 5. лабораторная работа №2 СИБГУТИ ДО
Состав работы
|
|
|
|
|
|
|
|
|
|
Работа представляет собой rar архив с файлами (распаковать онлайн), которые открываются в программах:
- Microsoft Word
Описание
Лабораторная работа No2
Обработка списков в языках CLISP и SWI-PROLOG
Номер задачи выбирается по последней цифре пароля.
Присылаемый на проверку архив должен содержать 3 файла:
файл отчета, содержащий титульный лист, условие задачи, исходные
тексты программ и результаты работы программ (можно в виде
скриншотов);
файл с исходным текстом программы на языке CLISP;
файл с исходным текстом программы на языке SWI-PROLOG.
Задание на лабораторную работу
Напишите на двух языках CLISP и SWI-PROLOG программы для работы со
списками по заданию. Обязательно использование рекурсии. Ввод всех входных
данных должен запрашиваться с клавиатуры в процессе работы программы
(функции или предиката). В программе на языке CLISP не допускается
использование: функционалов, а в теле рекурсивной функции - операторов SET
и SETQ. В программе на SWI-PROLOG предикат после вывода результатов
работы должен успешно завершиться (на экране появится true. и приглашение
следующего ввода цели ?-).
Номер варианта выбирается по последней цифре пароля.
0. Осуществите в списке L циклический сдвиг на N элементов влево.
Например, для языка CLISP при L = (a s d f g), N = 3 функция должна вернуть
(f g a s d).
1. Удалите из списка L все вхождения элемента X.
Например, для языка CLISP при L=(1 2 1 3 1 1 2 5 6), X=1 функция должна
вернуть (2 3 2 5 6).
2. Сформируйте список без повторений из тех элементов исходного списка L,
которые встречаются больше одного раза.
Например, для языка CLISP при L=(5 1 2 1 3 5 5 7) функция должна вернуть
(5 1).
3. Из каждой группы подряд идущих элементов списка L оставьте только один.
Например, для языка CLISP при L=(1 1 a a 3 3 3 + + + +) функция должна
вернуть (1 a 3 +).
4. Удалите из списка L за каждым вхождением X один элемент, если такой
имеется и отличен от X.
Например, для языка CLISP при L=(a 8 2 a a 5 a) X=a функция должна вернуть
(a 2 a a a).
5. Вставьте в список L1 элементы другого списка L2 после каждого вхождения
X в L1.
Например, для языка CLISP при L1=(1 2 1 5 3), X=1, L2=(+ * z) функция
должна вернуть (1 + * z 2 1 + * z 5 3).
2
6. Осуществите в списке L циклический сдвиг на N элементов вправо.
Например, для языка CLISP при L = (a s d f g), N = 3 функция должна вернуть
(d f g a s).
7. Удалите из списка L все повторные вхождения элементов.
Например, для языка CLISP при L=(1 2 1 4 1 2 3) функция должна вернуть
(1 2 4 3).
8. Удалите из списка L перед каждым вхождением X один элемент, если такой
имеется и отличен от X.
Например, для языка CLISP при L=(1 2 1 1 3), X=1 функция должна вернуть
(1 1 1 3).
9. Сформируйте новый список, каждый элемент которого - это список из двух
элементов: самого элемента и числа его вхождений в исходный список L.
Например, для языка CLISP при L=(2 4 2 3 2 3) функция должна вернуть
((2 3) (4 1) (3 2)).
Методические указания к выполнению лабораторной работы No1
Пример. Скопируйте N раз каждый элемент списка L.
Программа на языке CLISP
(defun f()
(princ "Vvedite spisok ")
(terpri)
(setq L (read))
(princ "Vvedite N ")
(terpri)
(setq N (read))
(princ "Rezult= ")
(copy L N)
)
(defun copy(L N &optional (K 0))
(cond
((null L) L)
((= N 0) (copy (cdr L) K 0))
(t (cons (car L)(copy L (- N 1) (+ K 1))))
)
)
3
Скриншот работы программы:
Программа на языке SWI-PROLOG
goal:-writeln('Введите список'),read(L),writeln('Введите N'),
read(N),copy(L,N,L1),write('Результат:'),write(L1).
copy(L,N,L1):-copy(L,N,N,L1).
copy([],_,_,[]):-!.
copy([_|Tail],0,N,L1):-!,copy(Tail,N,N,L1).
copy([Head|Tail],N,K,[Head|L1]):-!,N1 is N-1,
copy([Head|Tail],N1,K,L1).
Скриншот работы программы:
4
Обработка списков в языках CLISP и SWI-PROLOG
Номер задачи выбирается по последней цифре пароля.
Присылаемый на проверку архив должен содержать 3 файла:
файл отчета, содержащий титульный лист, условие задачи, исходные
тексты программ и результаты работы программ (можно в виде
скриншотов);
файл с исходным текстом программы на языке CLISP;
файл с исходным текстом программы на языке SWI-PROLOG.
Задание на лабораторную работу
Напишите на двух языках CLISP и SWI-PROLOG программы для работы со
списками по заданию. Обязательно использование рекурсии. Ввод всех входных
данных должен запрашиваться с клавиатуры в процессе работы программы
(функции или предиката). В программе на языке CLISP не допускается
использование: функционалов, а в теле рекурсивной функции - операторов SET
и SETQ. В программе на SWI-PROLOG предикат после вывода результатов
работы должен успешно завершиться (на экране появится true. и приглашение
следующего ввода цели ?-).
Номер варианта выбирается по последней цифре пароля.
0. Осуществите в списке L циклический сдвиг на N элементов влево.
Например, для языка CLISP при L = (a s d f g), N = 3 функция должна вернуть
(f g a s d).
1. Удалите из списка L все вхождения элемента X.
Например, для языка CLISP при L=(1 2 1 3 1 1 2 5 6), X=1 функция должна
вернуть (2 3 2 5 6).
2. Сформируйте список без повторений из тех элементов исходного списка L,
которые встречаются больше одного раза.
Например, для языка CLISP при L=(5 1 2 1 3 5 5 7) функция должна вернуть
(5 1).
3. Из каждой группы подряд идущих элементов списка L оставьте только один.
Например, для языка CLISP при L=(1 1 a a 3 3 3 + + + +) функция должна
вернуть (1 a 3 +).
4. Удалите из списка L за каждым вхождением X один элемент, если такой
имеется и отличен от X.
Например, для языка CLISP при L=(a 8 2 a a 5 a) X=a функция должна вернуть
(a 2 a a a).
5. Вставьте в список L1 элементы другого списка L2 после каждого вхождения
X в L1.
Например, для языка CLISP при L1=(1 2 1 5 3), X=1, L2=(+ * z) функция
должна вернуть (1 + * z 2 1 + * z 5 3).
2
6. Осуществите в списке L циклический сдвиг на N элементов вправо.
Например, для языка CLISP при L = (a s d f g), N = 3 функция должна вернуть
(d f g a s).
7. Удалите из списка L все повторные вхождения элементов.
Например, для языка CLISP при L=(1 2 1 4 1 2 3) функция должна вернуть
(1 2 4 3).
8. Удалите из списка L перед каждым вхождением X один элемент, если такой
имеется и отличен от X.
Например, для языка CLISP при L=(1 2 1 1 3), X=1 функция должна вернуть
(1 1 1 3).
9. Сформируйте новый список, каждый элемент которого - это список из двух
элементов: самого элемента и числа его вхождений в исходный список L.
Например, для языка CLISP при L=(2 4 2 3 2 3) функция должна вернуть
((2 3) (4 1) (3 2)).
Методические указания к выполнению лабораторной работы No1
Пример. Скопируйте N раз каждый элемент списка L.
Программа на языке CLISP
(defun f()
(princ "Vvedite spisok ")
(terpri)
(setq L (read))
(princ "Vvedite N ")
(terpri)
(setq N (read))
(princ "Rezult= ")
(copy L N)
)
(defun copy(L N &optional (K 0))
(cond
((null L) L)
((= N 0) (copy (cdr L) K 0))
(t (cons (car L)(copy L (- N 1) (+ K 1))))
)
)
3
Скриншот работы программы:
Программа на языке SWI-PROLOG
goal:-writeln('Введите список'),read(L),writeln('Введите N'),
read(N),copy(L,N,L1),write('Результат:'),write(L1).
copy(L,N,L1):-copy(L,N,N,L1).
copy([],_,_,[]):-!.
copy([_|Tail],0,N,L1):-!,copy(Tail,N,N,L1).
copy([Head|Tail],N,K,[Head|L1]):-!,N1 is N-1,
copy([Head|Tail],N1,K,L1).
Скриншот работы программы:
4
Дополнительная информация
Уважаемый студент, дистанционного обучения,
Оценена Ваша работа по предмету: Функциональное и логическое программирование
Вид работы: Лабораторная работа 2
Оценка:Зачет
Дата оценки: 31.12.2018
Рецензия:Уважаемая
замечаний нет.
Галкина Марина Юрьевна
Оценена Ваша работа по предмету: Функциональное и логическое программирование
Вид работы: Лабораторная работа 2
Оценка:Зачет
Дата оценки: 31.12.2018
Рецензия:Уважаемая
замечаний нет.
Галкина Марина Юрьевна
Похожие материалы
Функциональное и логическое программирование
Михаил18
: 26 сентября 2019
Билет №4
1. На языке Clisp определите функцию, которая меняет местами второй и третий элементы произвольного списка (в теле функции разрешается использовать только следующие встроенные функции: CAR,CDR,CONS,APPEND,LIST,LAST,BUTLASTс одним аргументом,REVERSE).
2. Какое значение получит Xв результате операции сопоставления (унификации) списков [a,b,c,d] и [_,_,_|X] в языке SWI-Prolog?
200 руб.
Функциональное и логическое программирование
Михаил18
: 26 сентября 2019
Напишите на языке SWI-PROLOG программу для работы с базой данных по заданию. Начальная база данных должна храниться в файле. В программе должно присутствовать меню из 5 пунктов, реализующих следующие возможности:
1. просмотр содержимого динамической базы данных (при запуске программы динамическая база данных должна заполняться из файла базы данных только один раз и только в этом пункте);
2. добавления записи в динамическую базу данных (за один вход в этот пункт должна быть возможность добавлени
200 руб.
Функциональное и логическое программирование
Mikola456
: 27 мая 2016
Контрольная работа
Во вложении Word+prolog
Создание базу данных с расписанием движения поездов: номер поезда, пункт назначения, время отправления, время прибытия. Найти номер и время отправления ближайшего по-езда до Москвы. Текущее время вводится с клавиатуры.
700 руб.
Функциональное и логическое программирование
Mikola456
: 27 мая 2016
ЛАБОРАТОРНАЯ РАБОТА №1
Вариант задачи выбирается по последней цифре зачетной книжки. Текст функции сохраняйте в файле. Функция может вызывать вспомогательные функции. В теле функций использование операторов set и setq не допускается!
Опpеделите на языке ЛИСП и проверьте работу функции, осуществляющей циклический сдвиг в списке на n элементов вправо.
Например, для списка (a s d f g) , n = 3 функция должна вернуть (d f g a s) .
ЛАБОРАТОРНАЯ РАБОТА №1
Программы должны быть написаны на языке дв
500 руб.
Функциональное и логическое программирование
alfFRED
: 25 июня 2013
Введение.
Постановка задачи.
Математические и алгоритмические основы решения задачи.
Функциональные модели и блок-схемы решения задачи.
Программная реализация решения задачи.
Пример выполнения программы.
Заключение.
Список использованных источников и литературы.
10 руб.
Функциональное и логическое программирование
piligrim-24
: 17 января 2012
Зачетное задание по дисциплине «Функциональное и логическое программирование»
Билет №11
1. На языке Лисп составьте композицию из функций CAR и CDR, для которой результатом применения этой композиции к списку ((1 (2 (3))) 4 (5)) будет 3.
2. Какое значение получит X в результате операции сопоставления (унификации) списков [a,b,c,d,e] и [_|X] в Прологе?
50 руб.
Функциональное и логическое программирование. Контрольная работа. Вариант №5.
sibguter
: 20 января 2019
Напишите на языке SWI-PROLOG программу для работы с базой данных по заданию. Начальная база данных должна храниться в файле. В программе должно присутствовать меню из 5 пунктов, реализующих следующие возможности:
1. просмотр содержимого динамической базы данных (при запуске программы динамическая база данных должна заполняться из файла базы данных только один раз и только в этом пункте);
2. добавления записи в динамическую базу данных (за один вход в этот пункт должна быть возможность добавления
150 руб.
Функциональное и логическое программирование. Контрольная работа. Вариант № 5
gnv1979
: 30 ноября 2017
Вариант 5.
Сформируйте новый список из общих элементов двух списков (пересечение множеств).
Например: На Лиспе для списков (1 2 3 5) и (6 4 1 8 3) результатом будет список (1 3).
35 руб.
Другие работы
Экзамен. Физика (2-й семестр). Билет №14.
s-kim
: 16 февраля 2013
1. При скорости 15 км/ч тормозной путь автомобиля равен 0,5 м. Каким будет тормозной путь автомобиля при скорости 90 км/ч? Ускорение в обоих случаях одинаково. Ответ подробно обосновать.
2. Точка из состояния покоя начала двигаться по окружности радиусом 1 м и прошла путь 50 м за 10 с. Определить нормальное ускорение точки через 5 с после начала движения.
3. Найти ускорение тела массой m = 1 кг, спускающегося с наклонной плоскости (угол наклонной плоскости = 30). Коэффициент трения тела о плоск
150 руб.
Русский язык.Итоговый тест Синергия/МТИ 2023г
annaserg
: 3 августа 2024
Сдано в 2023г. Верно 25 из 30 вопросов. Скриншот с отметкой прилагается к работе.
После покупки Вы получите файл с ответами на вопросы которые указаны ниже:
1 Новые слова в языке – это …
2 Произносительные нормы устной речи называются … нормами
3 Согласные звуки, которые образуются в результате преодоления преграды воздушной струей, без участия голоса, называются …
4 Мягкий знак после шипящих пишется в …
5 Наречия не имеют окончания, так как …
6 Установите соответствие между
199 руб.
Анализ и диагностика ФХД. Вариант №1
karnaval
: 12 февраля 2014
Задача. Провести анализ доходов районного узла электросвязи.
Выполнить следующие действия.
1 Обработать исходные данные, свести их аналитические таблицы
2 Провести анализ доходов основной деятельности в подотраслевом разрезе. Оценить деятельность предприятия по увеличению доходов
3 Оценить влияние факторов на изменение доходов по СТС
4 Выявить основные резервы дальнейшего повышения доходов по СТС
5 Исследовать степень обоснованности установленных тарифов в увязке со спросом на услуги СТС
Теоретические аспекты социального служения как разновидности социальной работы
Elfa254
: 3 февраля 2014
Содержание
Глава I. Социальное служение как особая форма общественной деятельности
1.1 Понятие «социальное служение»
1.2 Социально значимые мотивы участия в социальном служении
Глава II. Место и роль социального служения в системе социальной работы
2.1 Объекты и субъекты социального служения как разновидности социальной работы
2.2 Процесс институциализации социального служения в системе современных общественных отношений
Заключение
Список использованной литературы и нормативных правовых актов
Пр
15 руб.