首页 > web前端 > js教程 > 如何在 JavaScript 中高效计算多个数组的笛卡尔积?

如何在 JavaScript 中高效计算多个数组的笛卡尔积?

Mary-Kate Olsen
发布: 2024-12-31 05:55:18
原创
979 人浏览过

How to Efficiently Calculate the Cartesian Product of Multiple Arrays in JavaScript?

在 JavaScript 中实现多个数组的笛卡尔积

多个数组的笛卡尔积包含输入数组中元素的每种可能的组合。此操作对于从一组数据生成所有可能的组合或排列至关重要。

1 行答案 (ES2020)

const cartesian = (...a) => a.reduce((a, b) => a.flatMap(d => b.map(e => [d, e].flat())));
登录后复制

解释

笛卡尔积的计算公式如下方式:

  1. Reduce:使用此方法迭代每个数组并将它们组合起来。
  2. flatMap:将缩减后的数组展平组合来自两个输入的所有可能的元素组合数组。
  3. 扁平:通过删除空数组或元素来简化嵌套数组。

示例

到将笛卡尔积应用于具有值的数组,请考虑以下内容示例:

const output = cartesian([1, 2], [10, 20], [100, 200, 300]);
登录后复制

预期输出为:

[
  [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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板