首先是上下文。我试图用 prolog 建模的是两个分开的图,都代表一组朋友,所以我可以在他们两个中放置关系friend(X,Y)
,并且,因为它没有意义,所以在这个模型中友谊不是相互的,我也把关系friend(Y, X)
。
所以这意味着两个图在它们的元素之间都有双向关系。
例如:
friend(foo1, foo2).
friend(foo2, foo1).
friend(foo3, foo4).
friend(foo4, foo3).
其中与 ,foo1
相关foo2
, and 也是如此foo3
,foo4
但前两个与另外两个无关。
因为是一群朋友,所以在同一个朋友群里,同一个群里的两个人不是朋友也是没有意义的,所以我用递归来判断一个人是否是另一个人的朋友。
definitivefriend(X, Z) :- friend(X, Z).
definitivefriend(X, Z) :- friend(X, Y), definitivefriend(Y, Z).
我遇到的问题是当我尝试检查一组中的一个人是否是另一组的一个人的朋友时。换句话说,检查一个图的一个元素是否与另一个图的另一个元素相关。
编译器(在本例中为 SWI-Prolog)没有得到 false (这是预期的结果),而是给了我out of local stack 的错误。
我想知道如何解决这个问题。
编辑
所以感谢 CapelliC,我有一个解决这个问题的方法。因为主要目标已经完成,但是还有一个次要问题我从现在开始描述它。
这是我正在使用的两个图表。请记住,我之前说过,两个图都是双向的。
这是我在序言中的程序:
writeit :- write('Frienship').
definitivefriend(X, Z) :- friend(X, Z), friend(Z, X).
definitivefriend(X, Y) :- friend(X, Z), X @< Z, definitivefriend(Z, Y), Y \= X.
friend(amanda, ryan). % graph1 %
friend(ryan, amanda).
friend(ryan, lisa).
friend(lisa, ryan).
friend(bryan, ryan).
friend(ryan, bryan).
friend(sara, ryan).
friend(ryan, sara).
friend(sara, simone).
friend(simone, sara). % graph2 %
friend(sandra, jeff).
friend(jeff, sandra).
friend(betty, jeff).
friend(jeff, betty).
friend(jeff, antonia).
friend(antonia, jeff).
friend(jeff, oskar).
friend(oskar, jeff).
friend(jeff, leslie).
friend(leslie, jeff).
这是我得到的一些输出
?- definitivefriend(amanda, ryan).
true . % It's correct, both nodes are neighbours %
?- definitivefriend(amanda, simone).
true . % It's correct, both nodes are in the same graph %
?- definitivefriend(ryan, simone).
true . % It's correct, same explanation as before %
?- definitivefriend(simone, amanda).
false. % It's wrong, expected result is true %
?- definitivefriend(ryan, jeff).
false. % It's correct, nodes are in different graphs %
?- definitivefriend(amanda, leslie).
false. % It's correct, same explanation as before %
?- definitivefriend(sandra, oskar).
false. % It's wrong, expected result is true %
?- definitivefriend(oskar, sandra).
false. % It's wrong, expected result is true %
?- definitivefriend(betty, oskar).
true . % It's correct, both nodes are in the same graph %
?- definitivefriend(oskar, betty).
false. % It's wrong, expected result is true %
正如我在评论中所说,即使有同一张图的某些元素(除了相邻的元素),也会definitivefriend
给我错误的信息。在某些情况下,当我执行时definitivefriend(X, Y)
我得到了真实,但是当我执行时definitivefriend(Y, X)
我得到了错误。