我试图让我的代码更加动态。我有一个包含以下内容的文件:
a(b1, c1, d1).
a(b2, c2, d2).
a(b3, c3, d3).
当我找到所有b1
时,我做了一个这样的列表:
[b1, b2, b3].
当文件中的 arity 发生变化时,例如,当 a(b1,c1,d1)
变得a(b1,c1,d1,e1)
时,我的代码不起作用。有没有办法解决这个问题?我正在使用SWI-Prolog。
start :-
consult('file.pl'),
solve(L1, L2, L3),
list_to_set(L1, X),
write(X).
solve(L1, L2, L3):-
findall(First, data(First, _, _), L1),
findall(Second, data(_, Second, _), L2),
findall(Third, data(_, _, Third), L3).
如果参数发生变化,您应该将参数放在列表中并使用nth1/3
顺便说一句,类似的问题在这里
start:-
consult('file.pl'),
sampling(Arity),
solve(Arity,LL),
list_to_set(LL, X),
write(X).
solve(Arity,LL):-
length(L,Arity),
P =.. [data|L],
findall(L1,(
for(1,N,Arity),
nth1(N,L,A),
findall(A,P,L1)),
LL).
sampling(Arity) :-
see('file.pl'),
read(P),
sampling(P,Arity),
seen.
sampling(end_of_file,_) :- !,seen,fail.
sampling(P,Arity) :-
functor(P,data,Arity),!.
sampling(_,Arity) :-
read(P),
sampling(P,Arity).