javascript笛卡尔积算法实现方法

2019-12-18,,,,

本文实例讲述了javascript笛卡尔积算法实现方法。分享给大家供大家参考。具体分析如下:

这里可根据给的对象或者数组生成笛卡尔积

//笛卡儿积组合
function descartes(list)
{
  //parent上一级索引;count指针计数
  var point = {};
  var result = [];
  var pIndex = null;
  var tempCount = 0;
  var temp  = [];
  //根据参数列生成指针对象
  for(var index in list)
  {
    if(typeof list[index] == 'object')
    {
      point[index] = {'parent':pIndex,'count':0}
      pIndex = index;
    }
  }
  //单维度数据结构直接返回
  if(pIndex == null)
  {
    return list;
  }
  //动态生成笛卡尔积
  while(true)
  {
    for(var index in list)
    {
      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)
        {
          return result;
        }
        //赋值parent进行再次检查
        index = pIndex;
      }
      else
      {
        point[index]['count']++;
        break;
      }
    }
  }
}

希望本文所述对大家的javascript程序设计有所帮助。

您可能感兴趣的文章:

  • JS笛卡尔积算法与多重数组笛卡尔积实现方法示例
  • JavaScript求一组数的最小公倍数和最大公约数常用算法详解【面向对象,回归迭代和循环】
  • JavaScript实现的贝塞尔曲线算法简单示例
  • javascript常用经典算法实例详解
  • 原生js的RSA和AES加密解密算法
  • JS常用加密编码与算法实例总结
  • javascript中解析四则运算表达式的算法和示例
  • JS随机洗牌算法之数组随机排序
  • JavaScript笛卡尔积超简单实现算法示例

《javascript笛卡尔积算法实现方法.doc》

下载本文的Word格式文档,以方便收藏与打印。