我正在尝试编写一个带有规则的 Prolog 程序,该规则good
需要一个列表,其中列表中的每个术语都是一个 Peano 数。当且仅当列表中的每个元素都大于前一个元素时,该规则才应该为真。
例如,以下示例应该是正确的:
good([]).
good([0]).
good([0,s(0)]).
good([0,s(s(0))]).
good([0,s(0),s(s(0))]).
以下示例应该是错误的:
good([s(0),0]).
good([0,s(0),0]).
这是我的代码:
plus(X,0,X).
plus(X,s(Y),s(Z)) :- plus(X,Y,Z).
geq(X,Y) :- plus(K,Y,X).
ge(X,Y) :- geq(X,Y), not(X = Y).
good([]).
good([X]).
good([H|T]) :- good(H,T).
good(X,[H|T]) :- ge(H,X), good(T).
但是,对于肯定查询good([0,s(0),s(s(0))])
,真假都是解决方案。
错误是什么?