Форум программистов, компьютерный форум, киберфорум
Lisp
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/8: Рейтинг темы: голосов - 8, средняя оценка - 5.00
Модератор
 Аватар для long399
2885 / 1840 / 933
Регистрация: 16.10.2013
Сообщений: 5,246
Записей в блоге: 15

Добавить символ звездочки после каждого неотрицательного элемента списка

07.09.2017, 06:39. Показов 1706. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не получается написать функцию, которая принимает на вход список, и преобразует его следующим образом: после каждого неотрицательного элемента добавляет звездочку. Например:

исходный список: (0 b a -2 4)
преобразованный список: ((0 *) b a -2 (4 *))

Помогите, пожалуйста!

Добавлено через 22 минуты
Ошибку выдает компилятор:
sh-4.4$ clisp main.lisp
*** - >: NIL is not a real number
Lisp
1
2
3
4
5
6
7
8
(defun f1 (list n)
           (if (>= (car list) 0)
           (append (cons (car list) n) (f1 (cdr list) n))
           (append(f1 (cdr list) n))
           )
)
 
(f1 '(2 -1 11) '*)
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.09.2017, 06:39
Ответы с готовыми решениями:

Как создать список,чтобы после каждого элемента списка был вставлен его порядковый номер?
Как создать список,чтобы после каждого элемента списка был вставлен его порядковый номер?

Удаление из списка каждого каждого второго элемента
Добрый день, можете пожалуйста написать и прокомментировать построчно код, решающий следующую задачу:

После каждого элемента списка добавить предшествующую ему часть списка
Пусть дан список. После каждого элемента добавьте предшествующую ему часть списка. Не совсем понимаю,как это сделать. Единственное,что я...

3
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
07.09.2017, 08:35
Лучший ответ Сообщение было отмечено long399 как решение

Решение

А зачем функции второй параметр (n)? Он не нужен. Ну и код нехорош.

Lisp
1
2
3
4
5
6
7
8
9
10
11
(defun f (lst)
  (cond ((null lst) nil)
        ((numberp (car lst)) 
         (cons (if (>= (car lst) 0) (list (car lst) '*) (car lst)) (f (cdr lst))))
        (t (cons (car lst) (f (cdr lst))))))
          
==> F
 
(f  '(0 b a -2 4))
 
==> ((0 *) B A -2 (4 *))
Добавлено через 3 минуты
Еще вариант:

Lisp
1
2
3
4
5
6
7
8
(defun f (lst)
  (mapcar (lambda (x) (if (and (numberp x) (>= x 0)) (list x '*) x)) lst))
 
==> F
 
(f  '(0 b a -2 4))
 
==> ((0 *) B A -2 (4 *))
2
Модератор
 Аватар для long399
2885 / 1840 / 933
Регистрация: 16.10.2013
Сообщений: 5,246
Записей в блоге: 15
07.09.2017, 08:41  [ТС]
Catstail, большое спасибо! Оба варианта отлично работают
0
 Аватар для _sg
4710 / 4405 / 380
Регистрация: 12.05.2012
Сообщений: 3,102
08.09.2017, 12:08
как вариант:
Lisp
1
2
3
4
5
6
7
8
9
(defun escort-plusp-zerop-with-asterisk (w)
  (loop for a in w 
        if (and (numberp a)
                (or (zerop a) (plusp a)))
        collect `(,a *)
        else collect a))
 
> (escort-plusp-zerop-with-asterisk '(0 b a -2 4))
((0 *) B A -2 (4 *))
Lisp
1
2
3
4
5
6
7
8
(defun escort-plusp-zerop-with-asterisk (w)
  (loop for a in w 
        if (and (numberp a) (>= a 0))
        collect `(,a *)
        else collect a))
 
> (escort-plusp-zerop-with-asterisk '(0 b a -2 4))
((0 *) B A -2 (4 *))
Lisp
1
2
3
4
5
6
(defun escort-plusp-zerop-with-asterisk (w)
  (loop for a in w collect
        (if (and (numberp a) (>= a 0)) `(,a *) a)))
 
> (escort-plusp-zerop-with-asterisk '(0 b a -2 4))
((0 *) B A -2 (4 *))
Lisp
1
2
3
4
5
6
7
8
(defun escort-plusp-zerop-with-asterisk (w &aux (a (car w)))
  (cond ((null w) nil)
        ((and (numberp a) (>= a 0))
         (cons `(,a *) (escort-plusp-zerop-with-asterisk (cdr w))))
        ((cons a (escort-plusp-zerop-with-asterisk (cdr w))))))
 
> (escort-plusp-zerop-with-asterisk '(0 b a -2 4))
((0 *) B A -2 (4 *))
Добавлено через 4 минуты
Lisp
1
2
3
4
5
6
(defun escort-plusp-zerop-with-asterisk (w &aux (a (car w)))
  (when w (cons (if (and (numberp a) (>= a 0)) `(,a *) a)
                (escort-plusp-zerop-with-asterisk (cdr w)))))
 
> (escort-plusp-zerop-with-asterisk '(0 b a -2 4))
((0 *) B A -2 (4 *))
Lisp
1
2
3
4
5
(defun escort-plusp-zerop-with-asterisk (w)
  (mapcar #'(lambda (a) (if (and (numberp a) (>= a 0)) `(,a *) a)) w))
 
> (escort-plusp-zerop-with-asterisk '(0 b a -2 4))
((0 *) B A -2 (4 *))
Lisp
1
2
3
4
5
6
7
(defun escort-plusp-zerop-with-asterisk (w)
  (when w ((lambda (a r) 
             (cons (if (and (numberp a) (>= a 0)) `(,a *) a) r))
           (car w) (escort-plusp-zerop-with-asterisk (cdr w)))))
 
> (escort-plusp-zerop-with-asterisk '(0 b a -2 4))
((0 *) B A -2 (4 *))
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.09.2017, 12:08
Помогаю со студенческими работами здесь

Добавить после каждого положительного элемента списка нулевой элемент
дан односвязный список. как добавить после каждого положительного элемента нулевой элемент и записать это в файл?

После каждого элемента списка, стоящего на четной позиции добавить элемент =-1
Не могу нормально написать программу.:wall: Вообщем, после каждого элемента спика, стоящего на четной позиции добавить элемент =-1.

Удалить из каждого списка два элемента после каждого элемента с нечетным значением и подсчитать количество удаленных
Вот честно не пойму как это сделать буду очень благодарен если кто-то поможет

Обработка списка: после каждого нуля добавить предшествующую часть списка
Дан список чисел, нужно после каждого нуля добавить предшествующую часть списка. Написал что-то, но не работает, выдает ошибку. sp _...

Вставить после каждого нечетного элемента первого списка наибольший элемент второго списка
Сформировать два списка из N целочисленных случайных элементов (N – вводится пользователем, значения элементов выбирать из диапазона ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru