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

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

07.09.2017, 06:39. Показов 1685. Ответов 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
38195 / 21128 / 4309
Регистрация: 12.02.2012
Сообщений: 34,736
Записей в блоге: 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,245
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru