This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
yap-6.3/Logtalk/examples/searching/depth_first1.lgt
pmoura 75392e54c7 Logtalk 2.15.0 release files.
git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@757 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
2003-02-05 00:15:28 +00:00

34 lines
674 B
Plaintext

:- object(depth_first(Bound),
instantiates(blind_search(Bound))).
:- info([
version is 1.0,
author is 'Paulo Moura',
date is 1998/3/23,
comment is 'Depth first state space search strategy.',
parnames is ['Bound']]).
:- uses(list).
search(Space, State, Bound, Solution) :-
depth(Space, State, Bound, [], Path),
list::reverse(Path, Solution).
depth(Space, State, _, Path, [State| Path]) :-
Space::goal_state(State).
depth(Space, State, Bound, Path, Solution) :-
Bound > 0,
Space::next_state(State, Next),
\+ list::member(Next, [State| Path]),
Bound2 is Bound - 1,
depth(Space, Next, Bound2, [State| Path], Solution).
:- end_object.