笛卡尔乘积算法js实现

全因子实验设计( DOE) :指所有因子的所有水平的所有组合都至少进行一次实验,可以估计所有的主效应和所有的各阶交互效应。

笛卡尔乘积:指在数学中,两个集合X和Y的笛卡尔积(Cartesian product),又称直积,表示为X × Y,第一个对象是X的成员而第二个对象是Y的所有可能有序对的其中一个成员。

输入:\[1,4,5,1,2,7,3,6]二维数组

输出:\[1,1,7,1,1,3,1,1,6, 1,2,7,1,2,3,1,2,6,4,1,7,4,1,3,4,1,6,4,2,7,4,2,3,4,2,6,5,1,7,5,1,3,5,1,6,5,2,7,5,2,3,5,2,6]

代码:

javascript 复制代码
function generateOrthogonalArray(cartesianArray) {
    if (!cartesianArray || cartesianArray.length === 0) {
        return [];
    }
    const result = [];
    const lengths = cartesianArray.map((arr) => arr.length);
    const total = lengths.reduce((acc, val) => acc * val, 1);

    for (let i = 0; i < total; i++) {
        const row = [];
        let index = i;
        for (let j = lengths.length - 1; j >= 0; j--) {
            const currentLength = lengths[j];
            const currentIndex = index % currentLength;
            row.unshift(cartesianArray[j][currentIndex]);
            index = Math.floor(index / currentLength);
        }
        result.push(row);
    }
    return result;
}
const data=[[1,4,5],[1,2],[7,3,6]];
const result = generateOrthogonalArray(data);
console.log(result);
相关推荐
顾凌陵2 分钟前
CSRF&SSRF漏洞攻击的溯源分析与实战
前端·csrf
用户6919026813394 分钟前
JS 初了解:从“网页玩具”到企业级语言的进化
javascript
月月大王的3D日记4 分钟前
Three.js 材质篇(中):从兰伯特到PBR,一篇文章看懂五种光照材质
前端·javascript
且白5 分钟前
leaflet切片变色、地图滤镜逻辑实现 colorfilter
前端·javascript
ylscode7 分钟前
黑客利用 GHOSTYNETWORKS 和 OMEGATECH 托管 JS 恶意软件基础设施
开发语言·安全·php·安全威胁分析
爱吃生蚝的于勒8 分钟前
QT开发第二章——信号和槽
c语言·开发语言·c++·qt
用户8876654266310 分钟前
Linux 终端入门:新手必须掌握的常用命令和基本思路
前端·操作系统
xcLeigh13 分钟前
Python入门:Python3 operator模块全面学习教程
开发语言·python·学习·教程·python3·operator
大叔带刺15 分钟前
使用python创建自己的专属星座签名APP:Name2Constell
开发语言·python·pygame
丷丩17 分钟前
MapLibre GL JS第30课:添加视频
javascript·音视频·gis·mapbox·maplibre gl js