请帮我解决这个问题:我有一个列表列表
[[1,2],[3,4]]
如何得到:
[1,3]
[1,4]
[2,3]
[2,4]
或者如果我有一个列表列表
[[1,2],[3,4],[6,7]]
如何得到:
[1,3,6]
[1,3,7]
[1,4,6]
[1,4,7]
[2,3,6]
[2,3,7]
[2,4,6]
[2,4,7]
请帮我解决这个问题:我有一个列表列表
[[1,2],[3,4]]
如何得到:
[1,3]
[1,4]
[2,3]
[2,4]
或者如果我有一个列表列表
[[1,2],[3,4],[6,7]]
如何得到:
[1,3,6]
[1,3,7]
[1,4,6]
[1,4,7]
[2,3,6]
[2,3,7]
[2,4,6]
[2,4,7]
访问单个列表元素的谓词是最基本的 Prolog 构建块:member/2
.
你想要一个所有列表元素的列表:maplist/3
做这样的映射。因此我们可以写
combine(Ls, Rs) :-
maplist(get1, Ls, Rs).
get1(L, E) :-
member(E, L).
请注意,这get1/2
只是我们交换member/2
参数所必需的。但是因为在(纯)Prolog 中我们描述的是参数之间的关系,所以我们可以交换参数的顺序并进一步简化它:
combine(Ls, Rs) :-
maplist(member, Rs, Ls).
测试输出:
?- combine( [[1,2],[a,b]], Xs).
Xs = [1, a] ;
Xs = [1, b] ;
Xs = [2, a] ;
Xs = [2, b].
%% this is the same as:
%% maplist( member, Xs, [[1,2],[a,b]]) :-
%% member( X1, [1,2] ),
%% member( X2, [a,b]), Xs = [X1,X2].
编辑
一个笑话:真的,我的第一个 combine/2 应该这样写
combine(Ls, Rs) :-
maplist(rebmem, Ls, Rs).
rebmem(L, E) :-
member(E, L).
你可以这样做:
lists([], []).
lists([[Head|_]|Lists], [Head|L]):-
lists(Lists, L).
lists([[_,Head|Tail]|Lists], L):-
lists([[Head|Tail]|Lists], L).
也就是说,取输入列表中第一个列表的第一个元素,然后递归地继续处理剩余的列表。作为第二次机会,跳过该元素并使用剩余的元素重做。