![]() |
Модераторы: Poseidon |
![]() ![]() ![]() |
|
steet |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 13.5.2007 Репутация: нет Всего: нет |
Условие:
Задан список L1. Построить список L2, удалив из списка L1 повторяющиеся элементы. (L2 - перечень различных элементов списка L1 входящих в него только 1 (!) раз). Ну никак не получается решить задачу, буду премного благодарен. |
|||
|
||||
cherep |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 74 Регистрация: 11.1.2006 Где: Москва Репутация: 1 Всего: 4 |
Тоже ради интереса познакомился с прологом, решил попинать Вашу задачку, с наскока не получилось, но гугл всемогущ
![]() там еще описан предикат delete_all, но в SWI-Prolog уже есть delete, так что если писать на нем, решение такое:
Это сообщение отредактировал(а) cherep - 14.5.2007, 00:40 |
|||
|
||||
Artemios |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 405 Регистрация: 14.8.2006 Где: Саратов, Россия Репутация: 2 Всего: 50 |
Если на SWI, то можно еще короче:
![]() -------------------- fib = 1: 1: [ x+y | (x,y) <- zip fib (tail fib) ] |
|||
|
||||
steet |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 13.5.2007 Репутация: нет Всего: нет |
cherep,
Artemios, спасибо за помощь, но к сожалению писать нужно на обычном прологе :( |
|||
|
||||
Artemios |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 405 Регистрация: 14.8.2006 Где: Саратов, Россия Репутация: 2 Всего: 50 |
Так cherep же дал ссылку, по которой:
только нужно еще разобраться, как в твоей версии Пролога проверяется неравенство элементов. В этом примере это <> , а в SWI \= -------------------- fib = 1: 1: [ x+y | (x,y) <- zip fib (tail fib) ] |
|||
|
||||
steet |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 13.5.2007 Репутация: нет Всего: нет |
Artemios,
но ведь в любом случае при неравенстве у нас получается только два варианта и изменять их только в этой позиции, верно же? ![]() ... delete_all (X,[Y|L],[Y|L1]):– X<>Y, delete_all (X,L,L1). ... вот только скомпоновать у меня не получается :( |
|||
|
||||
steet |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 13.5.2007 Репутация: нет Всего: нет |
в моей версии пролога неравенство такое <>
|
|||
|
||||
Artemios |
|
||||||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 405 Регистрация: 14.8.2006 Где: Саратов, Россия Репутация: 2 Всего: 50 |
Угу. э... а что компоновать? беру код:
сохраняю в файл, загружаю в Пролог и даю вопрос:
-------------------- fib = 1: 1: [ x+y | (x,y) <- zip fib (tail fib) ] |
||||||
|
|||||||
steet |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 13.5.2007 Репутация: нет Всего: нет |
Artemios,
простите что долго не отвечал, рассылка ответов в теме на e-mail не сработала :( http://img201.imageshack.us/my.php?image=prologrf3.jpg пишет "3 illegal keywords" пробовал заменить в коде delete_all(_,[],[]). delete_all(X,[X|L],L1):- delete_all(X,L,L1). delete_all(X,[Y|L],[Y|L1]):- X\=Y, delete_all(X,L,L1). list_set([],[]). list_set([H|T],[H|T1]) :- delete_all(H,T,T2), list_set(T2,T1). на delete_all(_,[],[]). delete_all(X,[X|L],L1):- delete_all(X,L,L1). delete_all(X,[Y|L],[Y|L1]):- X<>Y, delete_all(X,L,L1). list_set([],[]). list_set([H|T],[H|T1]) :- delete_all(H,T,T2), list_set(T2,T1). пишет тоже самое :( |
|||
|
||||
Artemios |
|
||||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 405 Регистрация: 14.8.2006 Где: Саратов, Россия Репутация: 2 Всего: 50 |
Так это ж Turbo Prolog. Что-нибудь наподобие такого:
сам проверить немогу, Турбы неимею. -------------------- fib = 1: 1: [ x+y | (x,y) <- zip fib (tail fib) ] |
||||
|
|||||
steet |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 13.5.2007 Репутация: нет Всего: нет |
Artemios
Работает, сейчас потестирую, спасибо, еще отпишу Это сообщение отредактировал(а) steet - 4.6.2007, 19:30 |
|||
|
||||
steet |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 13.5.2007 Репутация: нет Всего: нет |
Artemios
Спасибо за помощь! Если Вам не сложно, не могли бы Вы обяснить пункт CLAUSES что мы делаем в каждой строке. У нас преподаватель очень требовательный :( а обратиться за помощью больше не к кому. Вот так она выглядит, полностью рабочая:
|
|||
|
||||
![]() ![]() ![]() |
Правила форума "Центр помощи" | |
|
ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Более подробно с правилами данного раздела Вы можете ознакомится в этой теме. Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Центр помощи | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |