笛卡尔积(javascript

本文介绍了一个用于生成所有可能数组组合的递归算法。通过定义一个递归函数 toResult,该函数接受当前处理的数组索引及当前组合结果,能够生成由多个相同结构数组构成的所有可能组合。最终将所有组合结果保存在 result 数组中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



var aa=[1,2,3],bb=[1,2,3],cc=[1,2,3],dd=[1,2,3];
var zz=[aa,bb,cc,dd];//此处数组个数任意

var result=new Array();//结果保存到这个数组
function toResult(arrIndex,aresult)
{
  if(arrIndex>=zz.length) {result.push(aresult);return;};
  var aArr=zz[arrIndex];
  if(!aresult) aresult=new Array();
  for(var i=0;i<aArr.length;i++)
  {
    var theResult=aresult.slice(0,aresult.length);
    theResult.push(aArr[i]);
    toResult(arrIndex+1,theResult);
  }
}
toResult(0);//函数执行后result数组就是所需结果






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值