农夫山羊狼和卷心菜在Prolog通过广度第一搜索

时间:2014-03-06 03:40:05

标签: prolog breadth-first-search river-crossing-puzzle

我正在尝试使用广度优先技术解决Prolog中的The Farmer,Goat,Wolf,Cabbage谜题,我遇到了一些问题。当我尝试收集树的第二级的所有有效组合时,它失败了。这是相关的代码,

extend([Node|Path], NewPaths) :-
    bagof([NewNode, Node|Path],
        (s(Node, NewNode), not(member(NewNode, [Node|Path]))),
        NewPaths),
    !.
extend(Path, []).

s(state(X,X,W,C), state(Y,Y,W,C))
    :- opp(X,Y), not(unsafe(state(Y,Y,W,C))).
s(state(X,G,X,C), state(Y,G,Y,C))
    :- opp(X,Y), not(unsafe(state(Y,G,Y,C))). 
s(state(X,G,W,X), state(Y,G,W,Y))
    :- opp(X,Y), not(unsafe(state(Y,G,W,Y))).
s(state(X,G,W,C), state(Y,G,W,C))
    :- opp(X,Y), not(unsafe(state(Y,G,W,C))).
s(state(F,G,W,C), state(F,G,W,C))
    :- fail.

opp(e,w).
opp(w,e).

unsafe(state(X,Y,Y,C)) :- opp(X,Y).
unsafe(state(X,Y,W,Y)) :- opp(X,Y).

not(P) :-
    P, !, fail
    ;
    true.

扩展谓词是我看到问题的地方。当我在第一级运行它时,它工作正常,

?- extend([state(e,e,e,e)],[X]).
X = [state(w,w,e,e),state(e,e,e,e)]

当我运行第二级时,它失败了,

?- extend([state(w,w,e,e)],[X]).
no

它应该返回类似下面的内容,

X = [state(e,w,e,e),state(w,w,e,e),state(e,e,e,e)]

提前感谢您的所有帮助,非常感谢。

此致

达里安

1 个答案:

答案 0 :(得分:1)

如果我查询你的代码,我会

?- extend([state(w,w,e,e)],X).
X = [[state(e, e, e, e), state(w, w, e, e)], [state(e, w, e, e), state(w, w, e, e)]]

X是列表清单。然后我简化了extend / 2谓词,

extend([Node|Path], [Node|NewPaths]) :-
    bagof(NewNode,
        (s(Node, NewNode), not(member(NewNode, Path))),
        NewPaths).

我得到了

?- extend([state(w,w,e,e)],X).
X = [state(w, w, e, e), state(e, e, e, e), state(e, w, e, e)].

请注意,我使用[X]查询extend / 2.

BTW这个条款没用了

s(state(F,G,W,C), state(F,G,W,C))
    :- fail.