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

Список с подсписками

29.10.2013, 21:04. Показов 1492. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан список с подсписками вида ((1 (2 4 z 6) 7) 9 8 ... ). Подсчитать количество элементов, которые расположены на втором и на третем уровне вложености.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.10.2013, 21:04
Ответы с готовыми решениями:

Список с подсписками, ребра
Добрый вечер! Осталось сдать последнюю лабу по лиспу, и пока не выходит. Помогите пожалуйста) Задание: Есть список с подсписками,...

Дан список с подсписками вида
Дан список с подсписками вида ((1 (2 4 z 6) 7) 9 8 ...). Подсчитать сумму элементов, которые расположены на втором уровне вложености .

Написать функцию, которая линеаризует список с подсписками и одномерными массивами (векторами)
Помогите, пожалуйста.

4
 Аватар для _sg
4710 / 4405 / 380
Регистрация: 12.05.2012
Сообщений: 3,102
29.10.2013, 22:22
Лучший ответ Сообщение было отмечено как решение

Решение

Lisp
1
2
3
4
5
6
7
8
9
10
(defun dive-count (n w &aux (a (car w)) (d (cdr w)))
   (cond ((null w) 0)
         ((= n 0) (count-if #'atom w))
         ((atom a) (dive-count n d))
         ((+ (dive-count (1- n) a) (dive-count n d)))))
 
> (dive-count 2 '(a(b(c 1)d e)f((2(g))3)))
3
> (dive-count 3 '(a(b(c 1)d e)f((2(g))3)))
1
4
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38195 / 21128 / 4309
Регистрация: 12.02.2012
Сообщений: 34,733
Записей в блоге: 14
29.10.2013, 22:39
Лучший ответ Сообщение было отмечено как решение

Решение

На любом:

Lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
(defun num-lv (lst n)
  (cond ((= n 0) (apply '+ (mapcar #'(lambda (x) (if (atom x) 1 0)) lst)))
        ((null lst) 0)
        ((atom (car lst)) (num-lv (cdr lst) n))
        (t (+ (num-lv (car lst) (- n 1)) (num-lv (cdr lst) n)))))
 
==> num-lv
 
(num-lv '((1 (2 4 z 6) 7) 9 8) 0)
 
==> 2
 
(num-lv '((1 (2 4 z 6) 7) 9 8) 1)
 
==> 2
 
(num-lv '((1 (2 4 z 6) 7) 9 8) 2)
 
==> 4
 
(num-lv '((1 (2 4 z 6) 7) 9 8) 3)
 
==> 0
3
0 / 0 / 0
Регистрация: 21.10.2013
Сообщений: 9
29.10.2013, 23:26  [ТС]
спасибо большое за помощь!)
0
1075 / 968 / 113
Регистрация: 04.11.2012
Сообщений: 1,013
29.10.2013, 23:48
Лучший ответ Сообщение было отмечено как решение

Решение

Lisp
1
2
3
4
5
6
7
8
9
10
11
(defun F (lst n)
  (if (zerop n)
      (count-if #'atom lst)
      (F (reduce #'nconc (remove-if #'atom lst)) (1- n))))
 
> (F '(a (b (c 1) d e) f ((2 (g)) 3)) 2)
3
> (F '(a (b (c 1) d e) f ((2 (g)) 3)) 3)
1
> (F '((1 (2 4 z 6) 7) 9 8) 2)
4
3
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.10.2013, 23:48
Помогаю со студенческими работами здесь

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

По списку с подсписками построить список из положительных и список из отрицательных числовых элементов
Написать функцию, которая по списку с подсписками строит списки из положительных числовых элементов, отрицательных числовых элементов и...

Список с подсписками
Здравстуйте! Помогите, пожалуйста, с заданием. Я нашел это задание здесь но там никто не ответил Трунову( Так как сам не могу сделать...

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

Сформировать список с подсписками
Здравствуйте!!!Помогите реализовать задания: 1)Список, в котором каждый элемент является подсписком уровня, соответствующего его месту. ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 30.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru