Форум программистов, компьютерный форум, киберфорум
Lisp
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 11

Функционал - замена

05.11.2013, 14:03. Показов 1004. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.
Задание:
Дан список произвольной длины, который состоит из числовых и символьных атомов. Определить функционал, который числовые атомы увеличивает в 2 раза, а символьные меняет на атомы А. Пример: (1 b 3 c 5 f) ==> (2 a 6 a 10 a).
Мои наработки:
Lisp
1
2
3
4
5
(defun mapcar~ (fn list)
(cond ((null list ) nil)
(t (cons (funcall fn (car list)) (mapcar~ fn (cdr list))))))
(mapcar~ #'(lambda (x) (+ x 1)) '( 1 a 3 4 5))
==> (2 a 4 5 6)
С символьными атомами ничего придумать не смог. И здорово было бы собрать это все воедино.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.11.2013, 14:03
Ответы с готовыми решениями:

Определить функционал Аналогичный предикату MAPLIST для одноуровнего списка. (Используйте применяющий функционал FUNCALL)
определить функционал Аналогичный предикату MAPLIST для одноуровнего списка. (Используйте применяющий функционал FUNCALL). Заранее...

создать функционал
написать функционал от 2х аргументов.дан элемент и список-надо чтобы вернул список-например (f 'atom '(p k (d) (rs)) равно ( T T NIL NIL)

Определить функционал
Даны два числовых одноуровненных списка x=(x1, x2....xn) и y=(y1,y2....,yn) одинаковой длины, g- некоторая функция от двух переменных,...

3
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38173 / 21108 / 4307
Регистрация: 12.02.2012
Сообщений: 34,708
Записей в блоге: 14
05.11.2013, 14:14
Вот решение задачи (причем, на всех уровнях):

Lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
(defun task (lst)
  (mapcar #'(lambda (x) (if (listp x) 
                            (task x)
                            (if (numberp x) (+ x x) 'a))) lst))
==> task
 
(task '(1 2 3 s d f 7 8 9))
 
==> (2 4 6 a a a 14 16 18)
 
(task '(1 2 (3 s d) f 7 8 9))
 
==> (2 4 (6 a a) a 14 16 18)
1
 Аватар для _sg
4709 / 4404 / 380
Регистрация: 12.05.2012
Сообщений: 3,101
05.11.2013, 23:35
Lisp
1
2
3
4
5
6
7
8
(defun a-*2-change (w a n)
  (cond ((null w) nil)
        ((numberp (car w)) (cons (* (car w) n)
                                 (a-*2-change (cdr w) a n)))
        (t (cons a (a-*2-change (cdr w) a n)))))
 
> (a-*2-change '(1 b 3 c 5 f) 'a 2)
(2 A 6 A 10 A)
1
4528 / 3522 / 358
Регистрация: 12.03.2013
Сообщений: 6,038
06.11.2013, 00:05
zeeg_lynch, во-первых, зачем вы пишете неэффективную реализацию mapcar. Во-вторых, зачем cond, если хватило бы if:
Lisp
1
2
3
(if lst
    (blah-blah)
    nil)
В третьих, вам надо было просто лямбду нормальную написать:
Lisp
1
2
3
4
(lambda (x)
  (cond ((numberp x) (* 2 x))
        ((symbolp x) 'a)
        (t (error "FAIL!!!"))))
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.11.2013, 00:05
Помогаю со студенческими работами здесь

Определить функционал
Помогите пожалуйста. Степенным рядом называется функциональный ряд вида...

Задачка на функционал
Дан линейный список списков, которые имеют произвольную длину. определить функционал, который считает длину каждого из вложенных списков....

Описать функционал
Описать функционал (root f a b eps), который методом деления отрезка пополам находит корень xk уравнения f(x)=0 на отрезке существования...

исправить функционал
"Строка" представляет собой список, подсписки - "слова". Литера b заменяется сочетанием литер ( (d, d) в данном случае). нужно исправить...

Определить функционал
1) Даны два числовых одноуровненных списка x=(x1, x2....xn) и y=(y1,y2....,yn) одинаковой длины, g- некоторая функция от двух переменных,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru