我要编写一个执行此操作的程序:
?- pLeap(2,5,X,Y).
X = 2,
Y = 3 ;
X = 3,
Y = 4 ;
X = 4,
Y = 5 ;
X = 5,
Y = 5 ;
false.
(给出 2 到 5 之间的所有对 X,X+1,加上最后的特殊情况)。
这应该是解决方案。我真的不明白它是如何工作的,有人可以指导我吗?
pLeap(X,X,X,X).
pLeap(L,H,X,Y) :-
L<H,
X is L,
Y is X+1.
pLeap(L,H,X,Y) :-
L=<H,
L1 is L+1,
pLeap(L1,H,X,Y).
我会这样做:
pLeap(L,H,X,Y) :-
X >= L,
X =< H,
Y is X+1.
为什么它不起作用(最后忽略特殊情况)?