JS笛卡爾積算法與多重?cái)?shù)組笛卡爾積實(shí)現(xiàn)方法示例
本文實(shí)例講述了JS笛卡爾積算法與多重?cái)?shù)組笛卡爾積實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
js 笛卡爾積算法的實(shí)現(xiàn)代碼,據(jù)對(duì)象或者數(shù)組生成笛卡爾積,并介紹了一個(gè)javascript多重?cái)?shù)組笛卡爾積的例子,以及java實(shí)現(xiàn)笛卡爾積的算法與實(shí)例代碼。
一、javascript笛卡爾積算法代碼
例子,根據(jù)對(duì)象或者數(shù)組生成笛卡爾積。
//笛卡兒積組合
function descartes(list) {
//parent上一級(jí)索引;count指針計(jì)數(shù)
var point = {};
var result = [];
var pIndex = null;
var tempCount = 0;
var temp = [];
//根據(jù)參數(shù)列生成指針對(duì)象
for (var index in list) {
if (typeof list[index] == 'object') {
point[index] = {
'parent': pIndex,
'count': 0
}
pIndex = index;
}
}
//單維度數(shù)據(jù)結(jié)構(gòu)直接返回
if (pIndex == null) {
return list;
}
//動(dòng)態(tài)生成笛卡爾積
while (true) {
for (var index in list) {
tempCount = point[index]['count'];
temp.push(list[index][tempCount]);
}
//壓入結(jié)果數(shù)組
result.push(temp);
temp = [];
//檢查指針最大值問(wèn)題
while (true) {
if (point[index]['count'] + 1 >= list[index].length) {
point[index]['count'] = 0;
pIndex = point[index]['parent'];
if (pIndex == null) {
return result;
}
//賦值parent進(jìn)行再次檢查
index = pIndex;
} else {
point[index]['count']++;
break;
}
}
}
}
調(diào)用方法:
var result = descartes({'aa':['a','b','c','d'],'bb':['$','%','^','&']});
alert(result);//result就是笛卡爾積
二、js實(shí)現(xiàn)多重?cái)?shù)組笛卡爾積
例子:
<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;
}
//多個(gè)一起做笛卡爾積
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>
為加深對(duì)笛卡爾積的理解,這里推薦一篇java笛卡爾積的方法教程:http://www.dhdzp.com/article/129585.htm,大家可以參考下。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- javascript笛卡爾積算法實(shí)現(xiàn)方法
- JavaScript求一組數(shù)的最小公倍數(shù)和最大公約數(shù)常用算法詳解【面向?qū)ο?,回歸迭代和循環(huán)】
- JavaScript實(shí)現(xiàn)的貝塞爾曲線(xiàn)算法簡(jiǎn)單示例
- javascript常用經(jīng)典算法實(shí)例詳解
- 原生js的RSA和AES加密解密算法
- JS常用加密編碼與算法實(shí)例總結(jié)
- javascript中解析四則運(yùn)算表達(dá)式的算法和示例
- JS隨機(jī)洗牌算法之?dāng)?shù)組隨機(jī)排序
- JavaScript笛卡爾積超簡(jiǎn)單實(shí)現(xiàn)算法示例
相關(guān)文章
JS代碼判斷IE6,IE7,IE8,IE9的函數(shù)代碼
JS代碼判斷瀏覽器版本,支持IE6,IE7,IE8,IE9!做網(wǎng)頁(yè)有時(shí)候會(huì)用到JS檢測(cè)IE的版本,下面是檢測(cè)Microsoft Internet Explorer版本的三種代碼2013-08-08
兼容ie和firefox的鼠標(biāo)經(jīng)過(guò)(onmouseover和onmouseout)實(shí)現(xiàn)--簡(jiǎn)短版
兼容ie和firefox的鼠標(biāo)經(jīng)過(guò)(onmouseover和onmouseout)實(shí)現(xiàn)--簡(jiǎn)短版...2007-11-11
jQuery.extend()的實(shí)現(xiàn)方式詳解及實(shí)例
extend()函數(shù)是jQuery的基礎(chǔ)函數(shù)之一,作用是擴(kuò)展現(xiàn)有的對(duì)象2013-06-06
JS原型prototype和__proto__用法實(shí)例分析
這篇文章主要介紹了JS原型prototype和__proto__用法,結(jié)合實(shí)例形式分析了JS原型prototype和__proto__使用方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2020-03-03
JavaScript日期處理類(lèi)庫(kù)moment()獲取時(shí)間
moment.js是一個(gè)廣泛使用的JavaScript日期處理庫(kù),便于開(kāi)發(fā)者進(jìn)行日期的解析、驗(yàn)證、操作和格式化,通過(guò)引用并設(shè)置區(qū)域,可以輕松實(shí)現(xiàn)本地化日期和時(shí)間的處理,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-09-09
使用BootStrap實(shí)現(xiàn)表格隔行變色及hover變色并在需要時(shí)出現(xiàn)滾動(dòng)條
這篇文章主要介紹了使用BootStrap實(shí)現(xiàn)表格隔行變色及hover變色并在需要時(shí)出現(xiàn)滾動(dòng)條效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-01-01
javascript驗(yàn)證內(nèi)容為數(shù)字以及長(zhǎng)度為10的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇javascript驗(yàn)證內(nèi)容為數(shù)字以及長(zhǎng)度為10的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08
刷新頁(yè)面實(shí)現(xiàn)方式總結(jié)(HTML,ASP,JS)
多種方法實(shí)現(xiàn)頁(yè)面的刷新代碼2008-11-11

