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

Реверс списка, содержащего подсписки

30.03.2022, 23:51. Показов 657. Ответов 3

Студворк — интернет-сервис помощи студентам
Задание: Написать программу для реверса списка, содержащего подсписки.
Можете помочь, не знаю как исправить чтобы программа работала.
Prolog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
domains
list=integer*
list2=list*
 
Predicates
reverse(list2,list2)
append(list2,list2,list2)
reverse2(list,list)
 
clauses
reverse([X], [X]):- !.
reverse([X | Y], Z):-
    reverse (Y, W), append(W, [X], Z).
    
reverse2([],[]):-!.
reverse2([X|T],Z):- 
    reverse2(T,W),reverse(X,E),append(W,[E],Z).
 
append([],L,L):- !.
append([X|L1],L2,[X|L3]):-
    append(L1,L2,L3).
 
goal
reverse([[1,2],[3,4]],Z).
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.03.2022, 23:51
Ответы с готовыми решениями:

Разбиение списка на всевозможные подсписки
Помоните пожайлуста решить задачу: Построить все возможные подсписки заданного списка. Искал по поиску подобной задачи не нашел. Нужно...

Реверс n элементов исходного списка, начиная с i-го
я сам не разбираюсь в прологе так что подсобите кто чем может)

Реверс списка с подсписками на парных уровнях
Дан список с подсписками, нужно обернуть его парные уровни. Пример: ]]] --> ],5,4]] Есть такой код, но он пропускает где-то скобки,...

3
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38160 / 21095 / 4306
Регистрация: 12.02.2012
Сообщений: 34,679
Записей в блоге: 14
31.03.2022, 00:14
Цитата Сообщение от TheDarkyS Посмотреть сообщение
Написать программу для реверса списка, содержащего подсписки.
- не уверен, что такая задача имеет решение в типизированной версии Пролога...

В Swi все достаточно просто:

Prolog
1
2
3
rev([],[]).
rev([H|T],R) :- atom(H),rev(T,RT), append(RT,[H],R).
rev([H|T],R) :- rev(H,RH),rev(T,RT), append(RT,[RH],R).
0
0 / 0 / 0
Регистрация: 16.06.2021
Сообщений: 5
07.04.2022, 11:41  [ТС]
Спасибо за помощь, но я всё-таки смог сделать на Visual Prolog

Prolog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
domains
list=integer* 
list2=list* 
 
Predicates
reverse(list2,list2) 
reverse2(list,list) 
append(list2,list,list2) 
append2(list,list,list) 
 
 
clauses
 
reverse([], []):- !. 
reverse([X|Y], Z):-     
    reverse (Y, W),reverse2(X,E), append(W, E, Z).
    
 
reverse2([],[]):-!. 
reverse2([X|T],Z):- 
    reverse2(T,E),append2(E,[X],Z).
    
 
append([],L,[L]):- !.
append([X|R1],L2,[X|R3]):- 
    append(R1,L2,R3).
    
 
append2([],L,L):- !.
append2([X|R1],L2,[X|R3]):-
    append2(R1,L2,R3).
 
goal
reverse([[1,2],[3,4],[5,6]],Z).
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38160 / 21095 / 4306
Регистрация: 12.02.2012
Сообщений: 34,679
Записей в блоге: 14
07.04.2022, 12:32
Цитата Сообщение от TheDarkyS Посмотреть сообщение
но я всё-таки смог сделать на Visual Prolog
- это частный случай... Попробуй сделать в Visual Prolog реверс вот такого списка [1,2,[3,4],[5,[6,7]]]
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.04.2022, 12:32
Помогаю со студенческими работами здесь

На основе списка, содержащего любое количество цифр от 1 до 9, получить список из их двоичных значений
На основе списка, содержащего любое количество цифр от 1 до 9, получить список из их двоичных значений. Помогите пожалуйста

На основе списка, содержащего любое количество цифр от 1 до 9, получить список из их двоичных значений
На основе списка, содержащего любое количество цифр от 1 до 9, получить список из их двоичных значений.

VIP 7.5 Есть реверс списка. Нужно этот список разделить на два и результат вывести. Есть некие заготовки
implement main open core, console class predicates rev : (integer* List, integer* Tail, integer* Result ) . clauses ...

Реверс произвольного списка, включая подсписки (XLisp)
Здравствуйте! Поставлена следующая задача: Реверсировать произвольный список (включая подсписки). Вот решение: (defun ddin (h n) ...

Максимальный элемент списка, содержащего подсписки
Имею код, которые находит максимальный элемент списка из атомов ( defun findMax(List) (cond ((null List) nil) ((null (cdr List))...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru