求笛卡尔积

有这样一个需求:

  商品有多个种类的规格,比如:

  颜色    大小     是否加厚

  红色    S         加厚

  蓝色    L         不加厚

  黄色    XL

  白色    XXL

  现在需要生成不同规格组合的多种商品列表供用户选择;

这里就用到笛卡尔积的计算。

function soDkr(arr) {
  var item = arr.shift();
  function dkr(item1, item2) {
    var res = [
    ];
    for (var i in item1) {
      for (var j in item2) {
        if (item1[i] instanceof Array) {
          var as = item1[i].slice(0);
          as.push(item2[j]);
          res.push(as);
        } else {
          res.push([item1[i],
          item2[j]]);
        }
      }
    }
    return res;
  }
  for (var i in arr) {
    item = dkr(item, arr[i]);
  }
  return item;
}

调用如下:

soDkr([['红色','蓝色','黄色','白色'],['S','L','XL','XXL'],['加厚','不加厚']]);

运行结果为:

[["红色", "S", "加厚"], ["红色", "S", "不加厚"], ["红色", "L", "加厚"], ["红色", "L", "不加厚"], ["红色", "XL", "加厚"], ["红色", "XL", "不加厚"], ["红色", "XXL", "加厚"], ["红色", "XXL", "不加厚"], ["蓝色", "S", "加厚"], ["蓝色", "S", "不加厚"], ["蓝色", "L", "加厚"], ["蓝色", "L", "不加厚"], ["蓝色", "XL", "加厚"], ["蓝色", "XL", "不加厚"], ["蓝色", "XXL", "加厚"], ["蓝色", "XXL", "不加厚"], ["黄色", "S", "加厚"], ["黄色", "S", "不加厚"], ["黄色", "L", "加厚"], ["黄色", "L", "不加厚"], ["黄色", "XL", "加厚"], ["黄色", "XL", "不加厚"], ["黄色", "XXL", "加厚"], ["黄色", "XXL", "不加厚"], ["白色", "S", "加厚"], ["白色", "S", "不加厚"], ["白色", "L", "加厚"], ["白色", "L", "不加厚"], ["白色", "XL", "加厚"], ["白色", "XL", "不加厚"], ["白色", "XXL", "加厚"], ["白色", "XXL", "不加厚"]]

posted @ 2014-11-04 13:07  灵瞳  阅读(299)  评论(0编辑  收藏  举报