2

我使用 GNU Prolog 来解决问题。我定义了以下谓词:

% P is the product of X and Y
produit(X,Y,P) :- 
    between(2,200,X),
    between(2,200,Y),
    X #<# Y,
    X*Y #=# P.

% S is the sum of X and Y 
somme(X,Y,S) :-
    between(2,200,X),
    between(2,200,Y),
    X #<# Y,
    X+Y #=# S.

%je ne peux pas deviner
clue_one(X,Y) :-
    produit(X,Y,P),
    XX*YY #=# P,
    XX #\=# X,
    XX #\=# 1,
    YY #\=# 1,
    XX #\=# Y.

%je le savais
clue_two(S) :-
    forall(somme(X,Y,S), clue_one(X,Y)).

Prolog 说这clue_two(17)是真的,但是当我尝试时 findall(S, clue_two(S), L),GNU Prolog 返回空列表。为什么?

4

1 回答 1

2

forall/2事实上的标准谓词等价于:

forall(Generator, Test) :-
    \+ (Generator, \+ Test).

由于使用了否定,因此不会返回任何由调用Generator或调用产生的绑定Test

于 2014-05-23T15:58:55.877 回答