javascript笛卡尔积算法实现方法
本文实例讲述了javascript笛卡尔积算法实现方法。分享给大家供大家参考。具体分析如下:
这里可根据给的对象或者数组生成笛卡尔积
//笛卡儿积组合
functiondescartes(list)
{
//parent上一级索引;count指针计数
varpoint={};
varresult=[];
varpIndex=null;
vartempCount=0;
vartemp=[];
//根据参数列生成指针对象
for(varindexinlist)
{
if(typeoflist[index]=='object')
{
point[index]={'parent':pIndex,'count':0}
pIndex=index;
}
}
//单维度数据结构直接返回
if(pIndex==null)
{
returnlist;
}
//动态生成笛卡尔积
while(true)
{
for(varindexinlist)
{
tempCount=point[index]['count'];
temp.push(list[index][tempCount]);
}
//压入结果数组
result.push(temp);
temp=[];
//检查指针最大值问题
while(true)
{
if(point[index]['count']+1>=list[index].length)
{
point[index]['count']=0;
pIndex=point[index]['parent'];
if(pIndex==null)
{
returnresult;
}
//赋值parent进行再次检查
index=pIndex;
}
else
{
point[index]['count']++;
break;
}
}
}
}
希望本文所述对大家的javascript程序设计有所帮助。
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短