我是prolog的新手。我正在尝试编写一个接受元素和列表的谓词,并检查列表中元素的出现并返回元素后面的其余列表。 例子是mypredicate(3,[1,2,3,4,5,6,7])返回[3,4,5,6,7]。 我希望我能解释一下。
mypredicate(X, [X|_]).
mypredicate(X, [_|T]) :- mypredicate(X,T).
这基本上只是检查列表中是否有元素。如何编写一个在X后返回列表其余部分的规则?
您需要返回基本情况中的所有列表,如:
mypredicate(X, [X|T],[X|T]).
该条款还包括:
mypredicate(X, [_|T]) :- mypredicate(X,T).
当列表的头部是X时使用,所以你需要确保在这种情况下头部与X不同:
mypredicate(X, [H|T],L) :- dif(X,H),mypredicate(X,T).
你应该添加第三个参数
mypredicate(X,[X|L],[X|L]).
mypredicate(X,[_|T],L) :- mypredicate(X,T,L).
如果您只对第一次出现的X
和L
感兴趣,请在第一条规则中添加一个剪切:
mypredicate(X,[X|L],[X|L]) :- !.
另一种方法,使用库(列表)谓词:
@ tim.newport评论后修正
mypredicate(X,L,[X|T]) :- append(_,[X|T],L).