|
1 / 1 / 0
Регистрация: 17.11.2011
Сообщений: 21
|
|
Рекурсивное преобразование списка06.01.2012, 03:26. Показов 4378. Ответов 25
Метки нет (Все метки)
Здравствуйте
Помогите пожалуйста с задачей: Используя приемы рекурсии в Лиспе, выполнить преобразование какого-либо одноуровневого списка вида (a b c d e f g h i j k l m n) получив список вида ((a) (b c) (d e f) (g h i j)), т.е. сгруппировать элементы списка увеличивая размер каждой последующей группы на 1 элемент. Спасибо за внимание
0
|
|
| 06.01.2012, 03:26 | |
|
Ответы с готовыми решениями:
25
Рекурсивное преобразование списков Рекурсивное преобразование списков Рекурсивное преобразование списков |
|
313 / 268 / 5
Регистрация: 03.04.2011
Сообщений: 456
|
||||||
| 06.01.2012, 04:52 | ||||||
3
|
||||||
|
1 / 1 / 0
Регистрация: 17.11.2011
Сообщений: 21
|
|
| 06.01.2012, 14:09 [ТС] | |
|
Огромное Вам спасибо! У меня действительно не было ни малейшего представления что так можно сделать.
Однако возникла другая проблема - оказывается, преподаватель требует чтобы задача была написана под PC-LISP 3.00. Я прошу прощения что не указал этого сразу, действительно был не в курсе(( Знающие люди, кто сможет переписать решение под PC-LISP 3.00?
0
|
|
|
313 / 268 / 5
Регистрация: 03.04.2011
Сообщений: 456
|
||||||
| 06.01.2012, 14:18 | ||||||
1
|
||||||
|
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
|
|
| 06.01.2012, 14:38 | |
|
bokunopico, я что-то не понял, в чём различие? cond в if разворачивается, или я не прав?
0
|
|
|
1 / 1 / 0
Регистрация: 17.11.2011
Сообщений: 21
|
|
| 06.01.2012, 14:49 [ТС] | |
|
bokunopico, И еще раз спасибо Вам огромное, все работает как надо!
У меня возник вопрос - нельзя ли в этой задаче обойтись без опционального аргумента? Я понимаю что без него увеличится код, но судя по тому что я с ним сталкиваюсь 1й раз в жизни, преподаватель несколько удивится что использован материал который он не давал
0
|
|
|
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
|
||||||
| 06.01.2012, 15:01 | ||||||
|
ну и?
Добавлено через 12 минут я пойму, если этот код работать не будет
0
|
||||||
|
313 / 268 / 5
Регистрация: 03.04.2011
Сообщений: 456
|
||||||||||||||||
| 06.01.2012, 19:57 | ||||||||||||||||
|
transformator.t, в PC-LISP нет такой конструкции:
O labels, судя по ошибке, создатели тоже подумали, как о чём-то лишнем. Добавлено через 1 минуту stvk, а что можно использовать?
0
|
||||||||||||||||
|
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
|
|
| 06.01.2012, 20:03 | |
|
0
|
|
|
313 / 268 / 5
Регистрация: 03.04.2011
Сообщений: 456
|
|
| 06.01.2012, 20:12 | |
|
Могу ещё добавить, что с loop он тоже не дружит, зато такой макрос, как do, там поддерживается.
0
|
|
|
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
|
|
| 06.01.2012, 20:19 | |
|
правильно - синтаксический сахар не нужен
0
|
|
|
313 / 268 / 5
Регистрация: 03.04.2011
Сообщений: 456
|
|
| 06.01.2012, 20:28 | |
|
Так вроде у loop гораздо шире возможности, нежели у do, значит, do надо было выкидывать из реализации. Вот с if правильно поступили: выражается через cond, множественное ветвление на нём неудобно читается, не нужен.
0
|
|
|
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
|
|
| 06.01.2012, 20:38 | |
|
а у iterate говорят есчё шире, но я его не юзаю, loop пока хватает.
мне if нравиться))
1
|
|
|
313 / 268 / 5
Регистрация: 03.04.2011
Сообщений: 456
|
|
| 06.01.2012, 20:41 | |
|
Спасибки, почитаю про iterate, правда я и loop-ом не умею пользоваться, но поскольку iterate круче, то loop для слабых.
0
|
|
|
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
|
|||||||
| 06.01.2012, 20:48 | |||||||
|
iterate придётся загружать)) типа quickload или asdf, ну а loop сразу в cl
![]() ну а чё loop? - хорошо
0
|
|||||||
|
313 / 268 / 5
Регистрация: 03.04.2011
Сообщений: 456
|
||||||
| 06.01.2012, 21:06 | ||||||
|
Кстати, а насколько плохо определять локальную рекурсивную функцию без labels? То есть напрямую через defun. Просто в SICP там это довольно широко применялось, но мы же не на Schemе пишем для ТС. Тогда ему можно предложить такой вариант без необязательных параметров:
1
|
||||||
|
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
|
|
| 06.01.2012, 21:15 | |
|
так labels - локальна, а defun - глобальна
ты сможешь iter вызывать, а оно тебе надо?
1
|
|
|
313 / 268 / 5
Регистрация: 03.04.2011
Сообщений: 456
|
||||||
| 06.01.2012, 21:27 | ||||||
|
Моя невнимательность, объяснюсь:
0
|
||||||
|
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
|
|
| 06.01.2012, 21:33 | |
|
ачоу
0
|
|
|
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
|
|
| 07.01.2012, 04:39 | |
|
bokunopico, defun, ЕМНИП, создает глобальную привязку, а define — локальную
1
|
|
| 07.01.2012, 04:39 | |
|
Помогаю со студенческими работами здесь
20
ПРеобразование списка Преобразование списка
Преобразование списка в список простых чисел Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|