Форум программистов, компьютерный форум, киберфорум
Lisp
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
32 / 32 / 9
Регистрация: 10.01.2010
Сообщений: 276
1

Рекурсия. Лисп

22.02.2011, 17:57. Показов 2054. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день! Есть такая задача
Дан список (a b c d). Необходимо преобразовать его в список (a (b) c (d)) используя рекурсию.
Делаю так
(defun mf1 (l)
(cond
((null l) nil)
(t (cons (cons (car l) (list (cadr l))) (mf1 (cddr l)) ) )
)
)
вбиваем
-->(mf1 '(a b c d))

а по факту
((a b) (c d))
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.02.2011, 17:57
Ответы с готовыми решениями:

Рекурсия в лисп
Добрый вечер! Задание таковое нужно со списка (a b c d e f g h) => ((h a) (g b) (f c) (e d)) ...

Функция, лисп
Пусть x – числовой список, n и m – целые числа (n<m). Определить функцию высшего порядка (udalen...

інтерпритатора Лисп
Помогите пожалуйста.Вычислите с помощью інтерпритатора Лисп 77-21.3+1.54*2.5432-32

Лисп. Функционалы
Здравствуйте , помогите пожалуйста. Задача Написать программу с использованием...

3
VH
428 / 256 / 23
Регистрация: 23.11.2010
Сообщений: 278
22.02.2011, 19:19 2
Lisp
1
2
3
4
5
6
7
8
9
10
(defun F (L)
 (cond
  ((null L) nil)
  ((null (cdr L)) L)
  (T
   (cons
    (car L)
    (cons
     (list (cadr L))
     (F (cddr L)))))))
0
Модератор
Эксперт функциональных языков программированияЭксперт Python
36606 / 20334 / 4221
Регистрация: 12.02.2012
Сообщений: 33,651
Записей в блоге: 13
25.01.2013, 19:24 3
Lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
(defun task (lst &optional flg)
  (cond ((null lst) Nil)
        ((null flg) (cons (car lst) (task (cdr lst) (not flg))))
        (t (cons (list (car lst)) (task (cdr lst) (not flg))))))
 
==> task
 
(task '(a b c d e f))
 
==> (a (b) c (d) e (f))
 
;;или так (HomeLisp):
 
(defun task (lst)
 (let ((res nil) (flg nil))
   (iter (for i in lst) (if flg (collecting (list i) into res) (collecting i into res))
    (setq flg (not flg))
   ) res )) 
 
==> task
 
(task '(a b c d e f))
 
==> (a (b) c (d) e (f))
0
4699 / 4394 / 380
Регистрация: 12.05.2012
Сообщений: 3,096
25.01.2013, 21:47 4
Lisp
1
2
3
4
5
6
7
8
9
(defun list-cadr (w)
  (if (cdr  w)
      (cons (car w) (cons (list (cadr w)) (list-cadr (cddr w))))
      w))
 
> (list-cadr '(a b c d))
(A (B) C (D))
> (list-cadr '(a b c d e))
(A (B) C (D) E)
1
25.01.2013, 21:47
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
25.01.2013, 21:47
Помогаю со студенческими работами здесь

Учить ли Лисп?
Уважаемые форумчане, у меня чисто гуманитарный вопрос, прошу посоветовать.. В следующем году сдаю...

Проги на ЛИСП.
Здравствуйте. Помогите пожалйста решить некоторые задачи на ЛИСП. Знаю, что они не сложные, просто...

Цикл в лисп
Здравствуйте. Есть такой код. (setf lst '(x1 x2 x3 x4)) (setf x1 2) (setf x2 3) (setf x3 4)...

Замыкание в лисп
объясните на примере вида (funcall замыкание)


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru