1. Написать программу нахождения последнего элемента списка. Для нахождения последнего элемента списка используйте двунарный предикат last(type_of_elements, list). Первый аргумент этого предиката задает последний элемент списка, второй – список, в котором производится поиск последнего элемента. Т. о. цель last(X, L) согласуется с базой данных, если элемент X является последним элементом списка L.
Например:
?- last(3, [1, 2, 3])
Yes
?- last(X, [1, 2, 3])
2. Написать программу исключения первого вхождения элемента в список. Для исключения первого вхождения некоторого элемента в список используйте предикат exclude(type_of_elements, list, list). Цель exclude(X, Y, Z) исключает первое вхождение элемента X в список Y, формируя новый список Z.
Например:
?- exclude(2, [1, 2, 3, 2], Z)
Z=[1, 3, 2]
3. Написать программу обращения списка. Обращенный список можно получить путем присоединения головы этого списка к обращенному хвосту. Для решения задачи используйте двунарный предикат reverse(list, list). Первый аргумент этого предиката задает начальный список, второй – обращенный.
Например:
?- reverse([1, 2, 3], Y)
Y=[3, 2, 1]
4. Написать программу поиска минимального элемента списка и его порядкового номера в этом списке. Для решения задачи используйте тринарный предикат minimum(type_of_elements, integer, list). Первый аргумент в этом предикате задает минимальный элемент списка, второй – индекс этого элемента в списке, третий – список, в котором производится поиск минимального элемента. Т. о. цель minimum(X, N, L) согласуется с базой данных, если X является минимальным элементом списка L, а N – порядковый номер элемента X в этом списке.
Например:
?- minimum(1, 4, [2, 5, 3, 1, 7])
Yes
?- minimum(X, N, [2, 5, 3, 1, 7])
X=1, N=4
5. Написать программу сортировки элементов списка с помощью прямого включения. При сортировке включением каждый элемент списка рассматривается отдельно и включается в новый список на соответствующее место. Алгоритм этой сортировки следующий:
FOR i := 2 TO n DO
x := a[i];
включение x на соответствующее место среди
a[1] ... a[i]
END
Пример сортировки списка с помощью прямого включения:
начальный список 44 55 12 42
i = 2 44 55 12 42
i = 3 12 44 55 42
i = 4 12 42 44 55
Для решения задачи используйте двунарный предикат insertion_sort(list, list). Первый аргумент в этом предикате задает начальный список, второй – отсортированный.