我想创建一个由N
元素组成的列表。
我写了以下代码:
DOMAINS
list = integer*
PREDICATES
create(integer, integer, list)
CLAUSES
create(_, 0, []).
create(Start, End, [Start|T]):-
Start < End + 1,!,
Counter = Start + 1,
create(Counter, End, T).
GOAL
create(1, 5, L).
但它返回No Solution
。
另一方面,如果我像这样改变Counter
的方向:
DOMAINS
list = integer*
PREDICATES
create(integer,list)
CLAUSES
create(0,[]).
create(N,[N|T]):-
N > 0,
NN = N - 1,
create(NN,T).
GOAL
create(5,L).
它返回1解决方案:L=[5,4,3,2,1]
。它工作得很好,但不在订单中。
我的第一个代码变体有什么问题?
答案 0 :(得分:1)
在第一个变体中,基本情况是错误的:
create(_, 0, []).
此处End
参数为0,但您的非基本规则永远不会修改End
,它在Start
上运行。
因此,只要Start
等于End
:
create(E, E, []).
答案 1 :(得分:1)
您需要对您的计划进行一些调整:
计划:
create(X, X, [X]):- !.
create(Start, End, [Start|T]):-
Start =\= End,
Counter is Start + 1,
create(Counter, End, T).
咨询(您需要实例化列表,因此请使用变量而不是空列表)
?- create(1,5, L).
L = [1, 2, 3, 4, 5].