zoukankan      html  css  js  c++  java
  • 求笛卡尔积

    有这样一个需求:

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

      颜色    大小     是否加厚

      红色    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", "不加厚"]]

  • 相关阅读:
    为表增加列属性方法探究
    细聊冗余表数据一致性
    缓存架构设计细节二三事
    缓存与数据库一致性保证
    MySQL批量SQL插入性能优化
    Codeforces 1150
    Codeforces 1155
    Codeforces 331D
    Windows & Ubuntu Vscode 配置c++环境
    后缀数组
  • 原文地址:https://www.cnblogs.com/lingtong/p/4073419.html
Copyright © 2011-2022 走看看