我想编写一个 Prolog 程序来查找两个列表的相等性,其中元素的顺序
无关紧要。所以我写了以下内容:
del(_, [], []) .
del(X, [X|T], T).
del(X, [H|T], [H|T1]) :-
X \= H,
del(X, T, T1).
member(X, [X|_]).
member(X, [_|T]) :-
member(X, T).
equal([], []).
equal([X], [X]).
equal([H1|T], L2) :-
member(H1, L2),
del(H1, L2, L3),
equal(T, L3).
但是,当我提供类似的输入时equal([1,2,3],X).
,它并没有显示所有可能的值X
。相反,程序挂在中间。可能是什么原因?