使用Prolog中的剪切操作从数据库中选择事实

我需要使用Prolog的剪切操作从事实数据库中获取第一个、第二个和最后一个事实。我已经找到了获取第一个和第二个事实的方法,但无法找到获取最后一个事实的解决方案。以下是一个示例:

P(jack).P(john).P(alice).P(sarah).P(kyle).

仅选择第一个事实:first(X):-P(X),!.

仅选择第二个事实:second(Y):-P(X),P(Y),X\=Y,P(Y),!.

仅选择最后一个事实:?


回答:

我看不到不使用否定、累加器和成员服务谓词的方法,但由于否定(通过失败)是通过剪切实现的,我的猜测是这样的:

last_(Y) :- collect([], [Y|_]).collect(Seen, L) :-    p(X), \+ member(X, Seen), collect([X|Seen], L).collect(All, All).

你可以用一个显式的剪切操作来实现not_contains/2,代替\+ member(Elem,List)(读取Elem不在List中)。

顺便说一下,你的second/1谓词包含了一个冗余的调用:应该这样写

second(Y):-p(X),p(Y),X\=Y,!.

Related Posts

Keras Dense层输入未被展平

这是我的测试代码: from keras import…

无法将分类变量输入随机森林

我有10个分类变量和3个数值变量。我在分割后直接将它们…

如何在Keras中对每个输出应用Sigmoid函数?

这是我代码的一部分。 model = Sequenti…

如何选择类概率的最佳阈值?

我的神经网络输出是一个用于多标签分类的预测类概率表: …

在Keras中使用深度学习得到不同的结果

我按照一个教程使用Keras中的深度神经网络进行文本分…

‘MatMul’操作的输入’b’类型为float32,与参数’a’的类型float64不匹配

我写了一个简单的TensorFlow代码,但不断遇到T…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注