-1

我试图让我的代码更加动态。我有一个包含以下内容的文件:

a(b1, c1, d1).
a(b2, c2, d2).
a(b3, c3, d3).

当我找到 allb1时,我列了一个这样的列表:

[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).
4

2 回答 2

0

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).
于 2011-05-12T10:27:53.940 回答
0

如果数量发生变化,您应该将参数放在列表中并使用nth1/3

顺便说一句,这里有类似的问题

于 2011-05-12T09:03:22.310 回答