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

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 14:48:20
字體:
來源:轉載
供稿:網友

本文實例講述了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>

為加深對笛卡爾積的理解,這里推薦一篇java笛卡爾積的方法教程://m.survivalescaperooms.com/article/129585.htm,大家可以參考下。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript數據結構與算法技巧總結》、《JavaScript數學運算用法總結》、《JavaScript排序算法總結》、《JavaScript遍歷算法與技巧總結》、《JavaScript查找算法技巧總結》及《JavaScript錯誤與調試技巧總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 稻城县| 建瓯市| 屯门区| 马尔康县| 沅江市| 应用必备| 永和县| 绵竹市| 甘德县| 和平区| 韩城市| 环江| 扬中市| 北流市| 新和县| 确山县| 兴安县| 和平区| 金沙县| 无棣县| 沛县| 乡宁县| 烟台市| 丹东市| 开远市| 济南市| 卢龙县| 靖西县| 武平县| 勐海县| 兰坪| 井陉县| 洛阳市| 乌兰察布市| 中山市| 特克斯县| 定结县| 台州市| 田林县| 皋兰县| 新泰市|