РАССЫЛКИ ПОРТАЛА RFPRO.RU Лучшие эксперты в разделе Номер выпуска: | 1613 | Дата выхода: | 25.05.2016, 18:21 | Администратор рассылки: | Лысков Игорь Витальевич (Старший модератор) | Подписчиков / экспертов: | 23 / 8 | Вопросов / ответов: | 1 / 1 | Консультация # 189448: Язык Lisp. 1) Написать функцию возведения числа X в степень Y. (defun power (x y) (cond ((= y 0) 1) (t (* x (power x (- y 1))) ) ... Консультация # 189448: Язык Lisp.
1) Написать функцию возведения числа X в степень Y.
(defun power (x y) (cond ((= y 0) 1) (t (* x (power x (- y 1))) ) ) )
2) Вычислить значение функции y=10/(1+x), где x?[0..20] и изменяется с шагом h=0.5, все полученные значения хранить в списке.
(defun func (x) (setq y (/ 10 (+ 1 x))) (cond ((= x 20) (list x y)) (t (cons (list x y) (func (+ x 0.5))) ) ) )
>> loop for x in (func 4) do (print x) 3) Написать функцию удаления из списка элемента с указанным номером.
(defun kill# (a b) (cond ((= b 0) (cdr a)) ((atom a) a) (t (cons (car a) (kill# (cdr a) (- b 1))) ) ) )
4) Написать функцию удаления из списка первого встреченного элемента, соответствующего указанному значению.
(defun killf (a key) (cond ((atom a) a) ((= key (car a)) (cdr a)) (t (cons (car a) (killf (cdr a) key)) ) ) )
Может кто-то объяснитЬ, что мы тут делаем в каждой строке? Дата отправки: 20.05.2016, 09:58 Вопрос задал: Посетитель - 399158 (Посетитель) Всего ответов: 1 Страница онлайн-консультации » Консультирует Зенченко Константин Николаевич (Модератор): Здравствуйте, Посетитель - 399158!
Опишем используемые функции:
DEFUN | определяет функцию пользователя | ATOM | предикат возвращает истину, если переменная является атомом | CAR | функция возвращает голову списка | CDR | функция возвращает хвост списка | CONS | функция присоединяет голову к хвосту списка | COND | функция ветвления возвращает результат, если сработает соответсвующее условие | T | последняя строка функции ветвления, срабатывает, если не сработало ни одно условие верления | = | функция сравнивает переменную с прерменной или значением | + - * / | математичиские функции сложения, вычитания, умножения и деления |
(defun power (x y) = определяем функцию пользователя (cond = ветвление вычислительного процесса ((= y 0) 1) = проверяем равна ли переменная Y нулю, т.е. если степень равна нулю возвращается 1 (t = выполнить следующую строку в любом случае (* x (power x (- y 1))) = рекурсивно вызываем функцию с измененной степенью и полученный результат умножаем с переменной ) ) )
(defun func (x) (setq y (/ 10 (+ 1 x))) = вычисляем текущее значение переменной (cond ((= x 20) (list x y)) = возвращаем список из переменной и значения (t (cons (list x y) (func (+ x 0.5))) = соединяем ренее полученный список с текущим ) ) )
(defun kill# (a b) (cond ((= b 0) (cdr a)) = если переменная В равна нулю возвращается хвост списка ((atom a) a) = проверяется является ли А атомом, т.е. пустой ли список (t (cons (car a) (kill# (cdr a) (- b 1))) = востанавливаем список, без уже вычеркнутого элемента ) ) )
(defun killf (a key) (cond ((atom a) a) ((= key (car a)) (cdr a)) = проверяется, является ли голова списка нужным элементом (t (cons (car a) (killf (cdr a) key)) ) ) )
Удачи!
Оценить выпуск | Задать вопрос экспертам главная страница | стать участником | получить консультацию техническая поддержка Дорогой читатель! Команда портала RFPRO.RU благодарит Вас за то, что Вы пользуетесь нашими услугами. Вы только что прочли очередной выпуск рассылки. Мы старались. Пожалуйста, оцените его. Если совет помог Вам, если Вам понравился ответ, Вы можете поблагодарить автора - для этого в каждом ответе есть специальные ссылки. Вы можете оставить отзыв о работе портале. Нам очень важно знать Ваше мнение. Вы можете поближе познакомиться с жизнью портала, посетив наш форум, почитав журнал, который издают наши эксперты. Если у Вас есть желание помочь людям, поделиться своими знаниями, Вы можете зарегистрироваться экспертом. Заходите - у нас интересно! МЫ РАБОТАЕМ ДЛЯ ВАС! |
Комментариев нет:
Отправить комментарий