我有一个数据库看起来像;
airport(ist, 90).
airport(saw, 45).
airport(esb, 60).
airport(adb, 60).
airport(erz, 30).
airport(ayt, 90).
airport(mlx, 30).
airport(tzx, 30).
airplane(f1, ist, [esb,tzx,saw]).
airplane(f2, ist, [mlx,esb,erz,esb]).
airplane(f3, ist, [esb,ist,esb,ist]).
airplane(f4, saw, [ayt,saw,ayt,saw]).
airplane(f5, erz, [esb,erz,esb]).
airplane(f6, mlx, [ist,esb,tzx,saw]).
我有一个名为“测试”的谓词将两个列表作为参数。所以,如果你写 testing([ist],X)。你应该得到 X=[esb,mlx]。我写了这段代码。
testing([],[]).
testing([D|D1],[L|L1]) :-
airport(D,_),
airplane(_,D,[L|_]),
testing(D1,L1).
这有效,输出为:
[8] 60 ?- listConnections([ist],X).
X = [esb] ;
X = [mlx] ;
X = [esb].
但这不是我想要的。所以第一个问题是我需要像 X=[esb,mlx] 这样的单行答案。第二个问题是列表中不应该有重复的元素。我希望我的问题很清楚。任何帮助将不胜感激。