Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
42
Добавлен:
11.05.2015
Размер:
19.73 Кб
Скачать
Лаб. 1

1. Напишите функцию трех аргументов (list3 x y z) такую, что (list3 x y z) = (x y
z) для любых символьных выражений; не используйте функцию list.

2. Пусть x и y - символы, у которых имеется свойство val, значением которого
всегда является число. Напишите функцию от двух аргументов
valplus, значением которой была бы сумма значений свойства val
ее аргументов.

3. Напишите функцию, которая выдает истину, если ее аргумент удовлетворяет
хотя бы одному из следующих условий:
а) является списком из двух элементов;
б) является списком из двух атомов;
в) является списком из трех элементов.

4. Напишите с помощью композиции условных выражений функции от
четырех аргументов (and4 x1 x2 x3 x4) и (or4 x1 x2 x3 x4), совпадающие с
встроенными функциями and и or от четырех аргументов.

5. Напишите функцию, вычисляющую последний элемент списка.

6. Напишите функцию, осуществляющую циклическую перестановку
элементов в списке, т.е. (f g h j) -> (g h j f).

7. Определите функцию (f a b c), которая равна истине тогда и только тогда,
когда из отрезков с длинами a,b и c можно построить треугольник.

8. Определите функцию (f a b c), которая вычисляет список корней
квадратного уравнения a*x^2+b*x+c=0 (если корней нет, то список пустой).

9. Определите функцию, которая меняет местами первый и последний
элементы списка, оставляя остальные на своих местах.

10. Последовательность чисел Фибоначчи 1, 1, 2, 3, 5, 8, 13… строится по
следующему закону: первые два числа - единицы; любое следующее число
есть сумма двух предыдущих f(n)=f(n-1)+f(n-2). Напишите функцию (f n f1
f2) c накапливающимися параметрами f1 и f2, которая вычисляет n-ое число
Фибоначчи.

11. Определите умножение целых чисел (*2 x y) через сложение и вычитание.

12. Определите возведение в целую степень (^ x n) через умножение и деление.

13. Напишите функцию (fullength x), считающую полное количество атомов (не
равных nil) в списке x. Исходный список не предполагается одноуровневым.

14. Напишите функцию от двух аргументов x и n , которая создает список из n
раз повторенных элементов x.

15. Напишите функцию, которая из данного списка строит список списков его
элементов, например, (a b) -> ((a) (b)).

16. Определите функцию, зависящую от двух аргументов u и v, являющихся
списками, которая вычисляет список всех элементов u, не содержащихся в v.

17. Напишите функцию, аналогичную встроенной функции замены subst в
списке s выражения x на y, но производящую взаимную замену x на y, т.е. x-
>y, y->x.

Лаб. 2

1. Определите функцию, зависящую от двух аргументов u и v, являющихся
списками, которая вычисляет список всех элементов, содержащихся либо в
u, либо в v, но не одновременно в u и v.

2. Напишите функцию, осуществляющую замену элементов списка y на
соответствующие элементы списка x в списке w, например,
y=(a b), x=(1 2), w=((a b) a (c (a (a d)))) -> ((1 2) 1 (c (1 (1 d)))).

3. Определите функцию (f s), результатом которой является список,
получающийся после удаления на всех уровнях всех положительных
элементов списка чисел s.

4. Определите функцию (summa_digits n), результатом которой является сумма
цифр натурального числа n.

5. Определите функцию (f s), которая из данного списка s удаляет последний
элемент.

6. Напишите функцию (f L), выдающую в качестве результата предпоследний
элемент списка L, имеющего не менее двух элементов.

7. Напишите функцию (f X N V), которая выдает список, получающийся
после добавления X на N-е место в список V.

8. Напишите функцию (f N V), которая выдает список, получающийся после
удаления N-го элемента из списка V.

9. Напишите функцию (f L), которая выдает список, получающийся после
удаления из списка L всех элементов, стоящих на четных местах, например,
(f '(1 2 3 4 5 6)) = (1 3 5).

10. Напишите функцию (f X V), которая выдает список, получающийся из
списка V после удаления всех вхождений X на всех уровнях, например, (f
'(1 (2 3 (1)) (3 1)) 1) = ((2 3 nil ) (3)).

11. Определите функцию (f V), которая выдает список всех элементов списка
V, встречающихся в нем более одного раза.

12. Напишите функцию (f A B), которая вычисляет наименьшее общее кратное
двух целых положительных чисел A и B.

13. Напишите функцию (f A ), которая выдает список, получающийся из списка
A удваиванием каждого элемента, например, (f '(1 2 3) ) = (1 1 2 2 3 3)..

14. Пусть имеется список "структур client": ((a 29 3) (b 29 6) (c 40 2)). Первым
элементом каждого подсписка служит имя клиента, вторым - суточный
тариф, а третьим - количество дней, на которое взята автомашина. Напишите
функцию вычисляющую итоговую сумму оплаты, объединяющую выплаты
всех клиентов, данные о которых содержатся в списке.

15. Опишите функцию (f N L1), которая берет список целых чисел L1 и целое
число N и выдает список (L1 L2), где списки L2 и L3 такие, что числа из
исходного списка, меньшие, чем N, помещаются в список L2, а остальные - в
список L3.

16. Запрограммируйте функцию (f A B), распознающую, можно ли получить
список элементов A из списка элементов B посредством вычеркивания
некоторых элементов.
Алгоритм: Если A - пустой список, то ответом будет "да". В противном
случае нужно посмотреть, не пуст ли список B. Если это так, то ответом
будет "нет". Иначе нужно сравнить первый элемент списка A с первым
элементом списка B. Если они совпадают, то надо снова применить тот же
алгоритм к остатку списка A и остатку списка B. В противном случае нужно
снова применить тот же алгоритм к исходному списку A и остатку списка B.

17. Напишите предикат (p X Y L) - истинный тогда и только тогда, когда X и Y
являются соседними элементами списка L.

18. Определите функцию sum_tree(TreeOfInteger), вычисляющую сумму целых
чисел, являющихся вершинами списка TreeOfInteger, представляющего
бинарное дерево.

19. Напишите функцию (range M N), которая выдает список целых чисел,
расположенных между M и N включительно.

20. Напишите функцию для вычисления целочисленного квадратного корня из
натурального числа N, определяемого как число I, такое, что I*I ? N, но
(I+1)*(I+1) > N.

21. Напишите функцию (count L X), считающую число вхождений элемента X в
список L. Исходный список не предполагается одноуровневым.

22. Напишите функцию (f L N), которая циклически сдвигает вправо элементы
списка L на N позиций.

23. Напишите функцию (f L N), которая циклически сдвигает влево элементы
списка L на N позиций.

24. Напишите функцию (f x y), которая сравнивает два списка целых чисел,
используя лексикографическом порядок.

25. Напишите функцию, единственным аргументом которой являлся бы список
списков, объединяющую все эти списки в один.

26. Напишите функцию, которая определяет, является ли данное натуральное
число простым.
Воспользуйтесь более общей задачей:
(ispr n m) - "Число n не делится ни на одно число большее или равное m и
меньшее n".
Имеем (ispr n m) -истинно, во-первых, если n = m, и, во-вторых, если
истинно (ispr n m+1) и n не делится на m.

27. Определите функцию (f a n), которая от двух числовых аргументов
вычисляет величину a+a*(a+1)+a*(a+1)*(a+2)+...+a*(a+1)*...*(a+n).

28. Определите функцию (f n), вычисляющую сумму:
1*2*3+4*5*6+...+(n-2)*(n-1)*n.

29. Определите функцию (f s), которая в одноуровневом списке чисел s
переставляет все отрицательные элементы в начало списка, например, (f '(4 -
8 6 -9 -7)) -> (-8 -9 -7 4 6).

30. Определите функцию (f s), вычисляющую знакочередующую сумму a1-
a2+a3-a4+...+ak*(-1)^k для списка s, имеющего вид (a1 a2 a3 ... ak).

31. Определите функцию (f n), которая для натурального числа n
вычисляет 1!+2!+3!+...+n!.

32. Используя функционалы, напишите функцию, которая из данного списка
строит список списков его элементов, например, (a b) -> ((a) (b)).

33. Определите функцию (f s n), которая из списка чисел s создает новый
список, прибавляя к каждому атому число n. Исходный список не
предполагается одноуровневым.

34. Определите функцию (f s), которая из списка чисел s создает новый список,
меняя знак у каждого атома. Исходный список не предполагается
одноуровневым.

Лаб. 3

1. Определите функцию, зависящую от одного аргумента, которая по данному
списку вычисляет список его элементов, встречающихся в нем более одного
раза. Проверьте, как она будет работать на примере '(a a a a b a).

2. Определите функцию, зависящую от двух аргументов u и n, которая по
данному списку строит список его элементов, встречающихся в нем не
менее n раз. Проверьте работу этой функции на примере (a a b a c b c a b b d
a b) для n=1,2,5,0.

3. Определите функцию, обращающую список и все его подсписки
на любом уровне, например, (a b (c d) e) -> (e (d c) b a).

4. Напишите функцию, заменяющую Y на число, равное глубине
вложения Y в W, например, Y=a, W=((a b) a (c (a (a d)))) ->
((2 b) 1 (c (3 (4 d)))).

5. Напишите функцию, определяющую глубину первого вхождения элемента y
в список w.

6. Напишите функцию, которая делает из списка множество, т.е. удаляет все
повторяющиеся элементы.

7. Напишите функцию (exists p x), которая проверяет
"Существует ли элемент списка x, удовлетворяющий предикату p?"
(p - функция или функциональное имя ).

8. Напишите функцию, которая сортирует список чисел, используя алгоритм
простой вставки.

9. Напишите функцию (all p x), которая проверяет
"Для всех ли элементов списка x выполняется предикат p? "
(p - функция или функциональное имя ).

10. Напишите функцию, которая сортирует список чисел, используя алгоритм
простого выбора.

11. Определите функцию (f s), результатом которой является список,
получающийся из списка списков s после удаления всех подсписков,
содержащих числа.

12. Напишите функцию (filter p x), которая "фильтрует" (создает список)
элементы списка x, удовлетворяющие предикату p
(p - функция или функциональное имя ).

13. Определите функцию (f s), которая вычисляет список (m1 m2 m3),
состоящий из трех наибольших элементов списка s: m1 >= m2 >= m3.
Исходный список содержит не менее трех элементов.

14. Напишите функцию (count p x), которая подсчитывает, сколько атомов в
списке x удовлетворяет предикату p (p -функция или функциональное имя).
Список x не предполагается одноуровневым.

15. Напишите функцию (f L), которая выдает список, получающийся после
удаления всех повторных вхождений элементов в список L, например, (f '(a
b c d d a)) = (a b c d).

16. Напишите функцию (f L), которая считает количество различных элементов
списка L.

17. Напишите функцию (f X Y), которая возвращает список Z - "пересечение"
списков X и Y, т.е. список, содержащий их общие элементы, причем
кратность каждого элемента в списке Z равняется минимуму из его
кратностей в списках X и Y.

18. Напишите функцию (f X Y), которая возвращает список Z - "пересечение"
списков X и Y, т.е. список, содержащий их общие элементы, причем
кратность каждого элемента в списке Z равняется максимуму из его
кратностей в списках X и Y.

19. Определите функцию (ordered Tree), проверяющую является бинарное
дерево Tree является упорядоченным деревом целых чисел, т. е. число,
стоящее в любой вершине дерева, больше любого элемента в левом
поддереве и меньше любого элемента в правом поддереве. Указание. Можно
использовать вспомогательные функции (ordered_left X Tree) и
(ordered_right X Tree), которые проверяют, что X меньше (больше) всех
чисел в вершинах левого (правого) поддерева дерева Tree и дерево Tree -
упорядочено.

20. Вычисление с днями недели. Обозначим дни как 0 = воскресенье, 1 =
понедельник, ..., 6 = суббота. Определите функцию (f S N), которая
вычисляет какой будет день недели через N дней, если сегодня день недели
S.

21. Напишите функцию (f N), которая выдает список всех простых чисел,
меньших N.

22. Начиная с календаря Папы римского Грегориуса в 1752 сохраняется
следующее правило для високосных годов (годы с 366 днями):
? год, делимый на 4, - високосный год (например, 1972);
? но: если он делится на 100, это не високосный год (например, 1900);
? но: если он делится на 400, это - високосный год (например, 2000).
Напишите функцию (f N), которая выясняет, является ли год N високосным.

23. Напишите функцию (drop L N), которая удаляет N элементов с конца
списка L.

24. Напишите функцию (drop L N), которая удаляет N элементов с начала
списка L.

25. Напишите функцию (drop L N1 N2), которая удаляет элементы списка L с
позиции N1 до позиции N2 включительно.

26. Напишите функцию (takeWhile L P), которая в качестве результата выдает
список, состоящий из всех элементов списка L, начинает с начала списка и
до первого элемента, не удовлетворяющего данному предикату P. Например:
(takeWhile '(2 4 6 7 8 9) 'Evenp) = (2 4 6). (P - функция или функциональное
имя ).

27. Напишите функцию (dropWhile L P), которая в качестве результата выдает
список, состоящий из всех элементов списка L, начиная с первого элемента
списка L, не удовлетворяющего данному предикату P. Например: (dropWhile
'(2 4 6 7 8 9) 'Evenp) = (7 8 9). (P - функция или функциональное имя ).

28. Написать функцию для генерации всех перестановок элементов
списка, состоящего из попарно различных элементов
Алгоритм:
<Все перестановки множества M>=
если M - пустое множество, то (nil),
иначе
для всех x, принадлежащих M,
ОБЪЕДИНИТЬ
(ДОБАВИТЬ x на первое место в каждой из
<Все перестановки множества M
без элемента x> ).

29. Для представления римских цифр используются символы: I - один, V - пять,
X - десять, L - пятьдесят, C - сто, D - пятьсот, M - тысяча. Для изображения
числа с помощью римских цифр используются общеизвестные правила; так,
например, 482 - CDLXXXII, 1999 - MCMXCIX. Напишите функцию (f R),
которая проверяет, правильна ли запись некоторого числа римскими
цифрами R (R - список символов); например, (f '(I I I C)) = nil.

30. Для представления римских цифр используются символы: I - один, V - пять,
X - десять, L - пятьдесят, C - сто, D - пятьсот, M - тысяча. Для изображения
числа с помощью римских цифр используются общеизвестные правила; так,
например, 482 - CDLXXXII, 1999 - MCMXCIX. Напишите функцию (f R),
которая переводит число R, записанное римскими цифрами, в десятичную
запись; например, (f '(C D L X X X I I)) = 482. Исходное число не превышает
1999.

31. Для представления римских цифр используются символы: I - один, V - пять,
X - десять, L - пятьдесят, C - сто, D - пятьсот, M - тысяча. Для изображения
числа с помощью римских цифр используются общеизвестные правила; так,
например, 482 - CDLXXXII, 1999 - MCMXCIX. Напишите функцию (f N),
которая переводит целое число N из диапазона от 1 до 2000 римскими
цифрами; например, (f 482) = (C D L X X X I I).

32. Интерпретирующая функция для исчисления предикатов.
Постановка задачи.
В языке имеются только логические выражения. Правильные выражения (их
семь типов) следующие.

Тип Форма
логические константы true, false
переменные атомы
конъюнкция (and e1 e2)
дизъюнкция (or e1 e2)
отрицание (not e1)
квантор всеобщности (all x e)
квантор существования (exists x e)

Требуется, чтобы правильные логические выражения не содержали
свободных переменных. Примерами интерпретируемых правильных
выражений являются:
(all p (or p (not p)))
(exists p (and (all q (or p q)) p))
(or (exists p p) (all p p))
Вычисление таких выражений всегда приводит к значению true или false .
Для операций and, or, not используются обычные правила вычисления. При
вычислении формы all выражение e вычисляется дважды, сначала
переменная x получает значение true, а затем false. К результатам
применяется операция and. Аналогично форма exists также требует
вычисления выражения при двух различных значениях переменной. К
результатам применяется затем операция or.

33. Построить программу "сжать", назначение которой - преобразование
английских слов в их "звуковой" код. Этот процесс предусматривает
"сжатие" примерно одинаково звучащих слов в одинаковый их код - своего
рода, аббревиатуру этих слов. Слова "сжимаются" в соответствии со
следующими правилами:
? первая буква слова сохраняется;
? все последующие за ней гласные, а также буквы "h", "w" и "y"
удаляются;
? сдвоенные буквы заменяются одиночными;
? закодированное слово состоит не более чем из четырех букв, остальные
буквы удаляются.
Напишите функцию (f w), которая выдает результат сжатия слова,
представленного в виде списка букв w.
Примеры: (f '(b a r r i n g t o n)) = (b r n g) и (f '(l l e w e l l y n)) = (l n).

34. Множественное число большинства английских существительных
получается путем добавления буквы "s" к форме единственного числа. Но
если существительное заканчивается буквой "y", следующей за согласной,
множественное число образуется путем замены буквы "y" на сочетание "ies";
если же существительное заканчивается буквой "o", следующей за
согласной, множественное число образуется путем добавления сочетания
"es".
Напишите функцию (f W), вычисляющую множественное число для
английского слова, представленного списком букв W.

35. Булева формула есть терм, определяемый следующим образом: константы
true и false - булевы формулы; если X и Y - булевы формулы, то и списки (X
v Y), (X & Y), (~ X) - булевы формулы, здесь v и & - бинарные инфиксные
операторы дизъюнкции и конъюнкции, а ~ - унарный оператор отрицания.
Напишите функцию, распознающую логические формулы в дизъюнктивной
нормальной форме, т.е. формулы, являющиеся дизъюнкцией конъюнкций
литералов, где литерал - атомарная формула или ее отрицание.

36. Булева формула есть терм, определяемый следующим образом: константы
true и false - булевы формулы; если X и Y - булевы формулы, то и списки (X
v Y), (X & Y), (~ X) - булевы формулы, здесь v и & - бинарные инфиксные
операторы дизъюнкции и конъюнкции, а ~ - унарный оператор отрицания.
Напишите функцию, (negation_inward F1), которая выдает логическую
формулу F2, получающуюся из логической формулы F1 внесением всех
операторов отрицания внутрь конъюнкций и дизъюнкций.

37. Булева формула есть терм, определяемый следующим образом: константы
true и false - булевы формулы; если X и Y - булевы формулы, то и списки (X
v Y), (X & Y), (~ X) - булевы формулы, здесь v и & - бинарные инфиксные
операторы дизъюнкции и конъюнкции, а ~ - унарный оператор отрицания.
Напишите функцию (f T), определяющую, является ли данный терм T
булевой формулой.

38. Напишите функцию (f N K), которая выдает список всех
последовательностей (списков) длины K из чисел 1,2,...,N.

39. Напишите функцию (f N ), которая выдает список всех последовательностей
(списков) из N нулей и единиц, в которых никакая цифра не повторяется
три раза подряд (нет куска вида XXX).

40. Напишите функцию (f N ), которая выдает список всех последовательностей
(списков) из N нулей, единиц и двоек, в которых никакая цифра не
повторяется два раза подряд (нет куска вида XX).

41. Булева формула есть терм, определяемый следующим образом: константы
true и false - булевы формулы; если X и Y - булевы формулы, то и списки (X
v Y), (X & Y), (~ X) - булевы формулы, здесь v и & - бинарные инфиксные
операторы дизъюнкции и конъюнкции, а ~ - унарный оператор отрицания.
Напишите функцию, распознающую логические формулы в конъюнктивной
нормальной форме, т.е. формулы, являющиеся конъюнкцией дизъюнкций
литералов, где литерал - атомарная формула или ее отрицание.
Соседние файлы в папке Лабораторные