时间:2021-05-28
JavaScript实现笛卡尔积
注意:本文中所说的集合是指数学上的集合,不是es6里的Set。
整体思路如下:
实现代码如下:
descates.js
/** * Created by Hawk on 2016/6/18. */var DescartesUtils = { /** * 如果传入的参数只有一个数组,求笛卡尔积结果 * @param arr1 一维数组 * @returns {Array} */ descartes1:function(arr1){ // 返回结果,是一个二维数组 var result = []; var i = 0; for (i = 0; i < arr1.length; i++) { var item1 = arr1[i]; result.push([item1]); } return result; }, /** * 如果传入的参数只有两个数组,求笛卡尔积结果 * @param arr1 一维数组 * @param arr2 一维数组 * @returns {Array} */ descartes2: function(arr1, arr2) { // 返回结果,是一个二维数组 var result = []; var i = 0, j = 0; for (i = 0; i < arr1.length; i++) { var item1 = arr1[i]; for (j = 0; j < arr2.length; j++) { var item2 = arr2[j]; result.push([item1, item2]); } } return result; }, /** * * @param arr2D 二维数组 * @param arr1D 一维数组 * @returns {Array} */ descartes2DAnd1D: function(arr2D, arr1D) { var i = 0, j = 0; // 返回结果,是一个二维数组 var result = []; for (i = 0; i < arr2D.length; i++) { var arrOf2D = arr2D[i]; for (j = 0; j < arr1D.length; j++) { var item1D = arr1D[j]; result.push(arrOf2D.concat(item1D)); } } return result; }, descartes3: function(list) { var listLength = list.length; var i = 0, j = 0; // 返回结果,是一个二维数组 var result = []; // 为了便于观察,采用这种顺序 var arr2D = DescartesUtils.descartes2(list[0], list[1]); for (i = 2; i < listLength; i++) { var arrOfList = list[i]; arr2D = DescartesUtils.descartes2DAnd1D(arr2D, arrOfList); } return arr2D; }, //笛卡儿积组合 descartes: function(list) { if (!list) { return []; } if (list.length <= 0) { return []; } if (list.length == 1) { return DescartesUtils.descartes1(list[0]); } if (list.length == 2) { return DescartesUtils.descartes2(list[0], list[1]); } if (list.length >= 3) { return DescartesUtils.descartes3(list); } }};descartes.html
<!DOCTYPE html><html><head> <meta charset="UTF-8"> <title></title> <script type="text/javascript" src="descartes.js"></script></head><body><div id="resultDiv"></div><script type="text/javascript"> var arr1 = [1,2,3]; var arr2 = ["a", "b", "c", "d"]; var list = [arr1, arr2]; var list2 = [ [1,2,3], ["a", "b", "c"], ["A", "B"], ["啊","把","车","的"] ]; var result = DescartesUtils.descartes(list2); var html = ""; for (var i = 0; i < result.length; i++) { html = html + result[i].join(",") + "<br>"; } document.getElementById("resultDiv").innerHTML = html;</script></body></html>感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JavaScript笛卡尔积超简单实现算法。分享给大家供大家参考,具体如下:JS笛卡尔积算法functioncartesianProductOf(
本文实例讲述了javascript笛卡尔积算法实现方法。分享给大家供大家参考。具体分析如下:这里可根据给的对象或者数组生成笛卡尔积//笛卡儿积组合functio
本文实例讲述了JS笛卡尔积算法与多重数组笛卡尔积实现方法。分享给大家供大家参考,具体如下:js笛卡尔积算法的实现代码,据对象或者数组生成笛卡尔积,并介绍了一个j
笛卡尔积笛卡尔积是指在数学中,两个集合X和Y的笛卡尔积(Cartesianproduct),又称直积,表示为X*Y,第一个对象是X的成员而第二个对象是Y的所有可
本文实例讲述了Java基于递归和循环两种方式实现未知维度集合的笛卡尔积。分享给大家供大家参考,具体如下:什么是笛卡尔积?在数学中,两个集合X和Y的笛卡儿积(Ca