是否有优化的方式来按顺序压缩3个列表
zip(L1, L2, L3)
这样它们就会产生一个元组列表,例如:
L1 = [1, 2, 3, 4],
L2 = [a, b, c, d],
L3 = [1, 2, 3, 4],
元组的结果列表应如下所示:
[{1,a,1}, {2,b,2}, {3,c,3}, {4,d,4}]
答案 0 :(得分:10)
您似乎需要使用lists:zip3/3:
1> L1 = [1, 2, 3, 4].
[1,2,3,4]
2> L2 = [a, b, c, d].
[a,b,c,d]
3> L3 = [1, 2, 3, 4].
[1,2,3,4]
4> lists:zip3(L1, L2, L3).
[{1,a,1},{2,b,2},{3,c,3},{4,d,4}]
答案 1 :(得分:6)
1> lists:zip3([1,2,3,4],[a,b,c,d],[1,2,3,4]).
[{1,a,1},{2,b,2},{3,c,3},{4,d,4}]
2>
或者你可以手动实现它:
myzip3([], _, _) ->
[];
myzip3([X|Xs], [Y|Ys], [Z|Zs]) ->
[{X,Y,Z}|myzip3(Xs,Ys,Zs)].
或使用累加器:
myzip3acc(Xs, Ys, Zs) ->
myzip3acc_do([], Xs, Ys, Zs).
myzip3acc_do(Acc, [], _, _) ->
lists:reverse(Acc);
myzip3acc_do(Acc, [X|Xs], [Y|Ys], [Z|Zs]) ->
myzip3acc_do([{X,Y,Z}|Acc], Xs,Ys,Zs).
答案 2 :(得分:1)
zip3_cps([X|Xs], [Y|Ys], [Z|Zs], F) ->
zip3_cps(Xs, Ys, Zs, fun(L) -> F([{X,Y,Z}|L]) end);
zip3_cps([], _, _, F) ->
F([]).
测试:
1> cps:zip3_cps([1,2,3], [4,5,6], [7,8,9], fun(X) -> X end).
[{1,4,7},{2,5,8},{3,6,9}]