我想做FP等效的(伪代码):
var l1 = [ '1', '2', '3' ];
var l2 = [ 'a', 'b', 'c' ];
var table = []
for i in l1 {
var row = [];
for j in l2 {
row.push([i, j]);
}
table.push(row);
}
导致table ==
:
[
[["1", "a"], ["1", "b"], ["1", "c"]],
[["2", "a"], ["2", "b"], ["2", "c"]],
[["3", "a"], ["3", "b"], ["3", "c"]]
]
我通过以下方式实现了这一目标:
const headEquals = (x,y) => R.equals(R.head(x), R.head(y));
const transform = R.compose(
R.groupWith(headEquals),
R.xprod
);
const table = transform(l1,l2);
...但感觉不够优雅 - xprod
生成的中间数据结构正在丢弃输入结构,然后我们通过进行大量equals
比较来重新计算。
在Ramda实现这一目标的更好方法是什么?
答案 0 :(得分:5)
这似乎可以解决问题
R.map(R.xprod(__, l2), l1)
另一种方式
R.splitEvery(l2.length, R.xprod(l1, l2))