Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Помогите с задачей на прологе

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
Ustyugova



Зарегистрирован: 21.02.2008
Сообщения: 24

СообщениеДобавлено: Чт Май 15 2008 17:29    Заголовок сообщения: Помогите с задачей на прологе Ответить с цитатой

помогите кто-нибудь с задачей по прологу(компилятор Turbo Prolog 2.0) задача обход конем доски. Есть следующий листинг:
domains
X = integer.
XY = step(X,X).
Path = XY*.

predicates
nondeterm start(Path).
nondeterm solver(Path,X,Path).
nondeterm xod(XY,XY).
nondeterm select_step(Path,XY).
xod_ok(XY).
member(Path,XY).
back_path(Path,Path).
append(Path,Path,Path).


clauses
xod(step(X,Y),step(X1,Y1)):-X1=X+1,Y1=Y+2.
xod(step(X,Y),step(X1,Y1)):-X1=X-1,Y1=Y+2.
xod(step(X,Y),step(X1,Y1)):-X1=X+2,Y1=Y+1.
xod(step(X,Y),step(X1,Y1)):-X1=X+2,Y1=Y-1.
xod(step(X,Y),step(X1,Y1)):-X1=X-1,Y1=Y-2.
xod(step(X,Y),step(X1,Y1)):-X1=X+1,Y1=Y-2.
xod(step(X,Y),step(X1,Y1)):-X1=X-2,Y1=Y+1.
xod(step(X,Y),step(X1,Y1)):-X1=X-2,Y1=Y-1.

select_step([step(X,Y)|_],step(X1,Y1)):-xod(step(X,Y),step(X1,Y1)).

member([X|_],X):-!.
member([_|Y],X):-member(Y,X).

append([],L,L):-!.
append([H|T],L,[H|V]):-append(T,L,V).

back_path([],[]).
back_path([X|P],P1):-back_path(P,Z),append(Z,[X],P1).

xod_ok(step(X,Y)):-X>0,X<=8,Y>0,Y<=8.

solver(N,62,M):-!,back_path(N,M).

solver(Path,I,L):-select_step(Path,step(X,Y)),xod_ok(step(X,Y)),not(member(Path,step(X,Y))),I1=I+1,
solver([step(X,Y)|Path],I1,L).

start(N):-solver([step(1,1)],1,N).

нужно написать к нему запрос, но не получается пролог падает
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...