在数学中,多个集合的笛卡尔积是所有可能的集合这些集合中元素的有序组合。例如,集合 [1, 2] 和 [10, 20, 300] 的笛卡尔积为 { [1, 10], [1, 20], [1, 300], [2, 10], [2, 20], [2, 300] }.
1 行 JavaScript 解决方案(2020 更新)
利用现代 JavaScript 功能的强大功能,这里有一个超简洁的解决方案,只需一行:
const cartesian = (...a) => a.reduce((a, b) => a.flatMap(d => b.map(e => [d, e].flat())));
2 行普通 JavaScript解决方案
在 2020 年更新之前,这是最短的普通 JavaScript 解决方案:
let f = (a, b) => [].concat(...a.map(a => b.map(b => [].concat(a, b)))); let cartesian = (a, b, ...c) => b ? cartesian(f(a, b), ...c) : a;
考虑输入数组:
input = [1, 2], [10, 20], [100, 200, 300]
为了计算笛卡尔积,我们可以调用笛卡尔函数函数:
const output = cartesian(...input);
输出变量将包含预期的笛卡尔积:
[[1, 10, 100], [1, 10, 200], [1, 10, 300], [1, 20, 100], [1, 20, 200], [1, 20, 300], [2, 10, 100], [2, 10, 200], [2, 10, 300], [2, 20, 100], [2, 20, 200], [2, 20, 300]]
以上是如何在 JavaScript 中计算多个数组的笛卡尔积?的详细内容。更多信息请关注PHP中文网其他相关文章!