国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JS笛卡爾積算法與多重數組笛卡爾積實現方法示例

2024-05-06 16:41:12
字體:
來源:轉載
供稿:網友

本文實例講述了JS笛卡爾積算法與多重數組笛卡爾積實現方法。分享給大家供大家參考,具體如下:

js 笛卡爾積算法的實現代碼,據對象或者數組生成笛卡爾積,并介紹了一個javascript多重數組笛卡爾積的例子,以及java實現笛卡爾積的算法與實例代碼。

一、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;      }    }  }}

調用方法:

var result = descartes({'aa':['a','b','c','d'],'bb':['$','%','^','&']});alert(result);//result就是笛卡爾積

二、js實現多重數組笛卡爾積

例子:

<script>(function() {  dwn = function(a) {    document.writeln(a + "<br />")  };  //笛卡爾積  var Cartesian = function(a, b) {    var ret = [];    for (var i = 0; i < a.length; i++) {      for (var j = 0; j < b.length; j++) {        ret.push(ft(a[i], b[j]));      }    }    return ret;  }  var ft = function(a, b) {    if (! (a instanceof Array)) a = [a];    var ret = Array.call(null, a);    ret.push(b);    return ret;  }  //多個一起做笛卡爾積  multiCartesian = function(data) {    var len = data.length;    if (len == 0) return [];    else if (len == 1) return data[0];    else {      var r = data[0];      for (var i = 1; i < len; i++) {        r = Cartesian(r, data[i]);      }      return r;    }  }})();var data = [['a', 'b', 'c'], [1, 2, 3, 4], ['A', 'B'], ['#', '@', '+'], ['Mary', 'Terry', 'KYO']];var r = multiCartesian(data);for (var i = 0; i < r.length; i++) {  dwn("(" + r[i] + ")");}</script>

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 晋江市| 新化县| 肥西县| 罗田县| 永康市| 家居| 大同县| 潜江市| 长垣县| 鹤庆县| 辉县市| 玛纳斯县| 达拉特旗| 改则县| 贵南县| 麻城市| 肇东市| 教育| 内乡县| 清远市| 金昌市| 土默特左旗| 琼中| 寻乌县| 新田县| 雅安市| 水城县| 沽源县| 辽阳县| 安福县| 深州市| 巴中市| 新民市| 工布江达县| 道孚县| 花莲市| 东乡族自治县| 高州市| 湄潭县| 周宁县| 桐柏县|