TypeScript SKU 生成笛卡尔集

export const descartes = <T>(array: T[][]) => {
  if (array.length < 2) {
    return array[0]?.map(item => [item]) || [];
  }
  return Array.prototype.reduce.call(array, (col: (T | T[])[], set: T[]) => {
    let res: T[][] = [];
    col.forEach((c) => {
      set.forEach((s) => {
        let t: T[] = Array.isArray(c)? [...c] : [c]
        t.push(s);
        res.push(t);
      })
    });
    return res;
  });
}

参考

export const descartes = <T>(array: T[][]) => {
  return array.reduce((prev, cur) => {
    let res: T[][] = [];
    prev.forEach(p => cur.forEach(c => arr.push(p.concat([c]))))
    return res;
  }, [[]] as T[][])
}

参考

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容