检查元素后返回列表的Prolog谓词

问题描述 投票:1回答:2

我是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后返回列表其余部分的规则?

list prolog predicate
2个回答
2
投票

您需要返回基本情况中的所有列表,如:

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).

2
投票

你应该添加第三个参数

mypredicate(X,[X|L],[X|L]).
mypredicate(X,[_|T],L) :- mypredicate(X,T,L).

如果您只对第一次出现的XL感兴趣,请在第一条规则中添加一个剪切:

mypredicate(X,[X|L],[X|L]) :- !.

另一种方法,使用库(列表)谓词:

@ tim.newport评论后修正

mypredicate(X,L,[X|T]) :- append(_,[X|T],L).
© www.soinside.com 2019 - 2024. All rights reserved.