JavaScript獲取多個數(shù)組的交集簡單實(shí)例
更新時間:2013年11月11日 16:02:01 作者:
這篇文章介紹了JavaScript獲取多個數(shù)組的交集簡單實(shí)例,有需要的朋友可以參考一下
在項(xiàng)目中需要取得多個數(shù)組的交集,故本例只是適用于特定場景。比如A數(shù)組 var a = {1000,10001,10002,10003}; B數(shù)組 var b = {10002, 10003}; C數(shù)組var c = {10003}; 需要取得這三個數(shù)組的交集數(shù)組。
具體思路為:先初始一個最小數(shù)組為A數(shù)組,元素個數(shù)最小的也是數(shù)組A的長度.然后再迭代各個數(shù)組,取得這幾個數(shù)組長度最短的為最小長度,同時得到長度最短數(shù)組。然后,迭代最小數(shù)組與各個數(shù)組,開始比較元素相等,使用計數(shù)器來判斷是否該元素在各個數(shù)組中都存在即為交集元素.
思路比較簡單,但是可以實(shí)現(xiàn)多數(shù)組取得交集,代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<script>
function getValues(obj){
var values = "";
var l = obj.options.length;
for (var i=0; i<l; i++) {
if (i != (l-1)) {
values += obj.options(i).value + "_";
}
else {
values += obj.options(i).value;
}
}
return values;
}
function _test() {
var ids = getValues(document.all.aa);
var aa = _getIntersection(ids);
}
function _getIntersection(src) {
var tAry = src.split("_");
//最小數(shù)組
var minAry = null;
var min = tAry[0].split(",").length; //初始化第一個為長度最小的數(shù)組
minAry = tAry[0].split(",");
for (var i = 1, len = tAry.length; i<len; i++) {
var temp = tAry[i].split(",");
if (temp.length < min) {
min = temp.length;
minAry = temp;
}
}
alert("最小數(shù)組:"+minAry);
var ret = '';
for (var i = 0, len = minAry.length; i<len; i++) {
var srcNum = parseInt(minAry[i]);
var counter = 0;
for (var j = 0, ll = tAry.length; j<ll; j++) {
var tt = tAry[j].split(",");
for (var k = 0, l = tt.length; k<l; k++) {
var tarNum = parseInt(tt[k]);
if (srcNum == tarNum) {
counter ++;
}
}
}
if (counter == tAry.length) {
ret += srcNum + ",";
}
}
ret = strSlice(ret, ',');
alert("交集是:" + ret);
}
//去掉結(jié)尾分隔符
function strSlice(str, split){
if ((str!=null && str!="") && (split!=' '))
return ((str.charAt(str.length-1) == split) ? str.substring(0, str.length-1) : str);
else
return str;
}
</script>
</HEAD>
<BODY>
<button onclick="javascript:_test();">測試</button>
<select name="aa" id="aa" size="6" multiple>
<OPTION value="10004,10005,10008,10009,10010,10018">測試1</OPTION>
<OPTION value="10004,10005,10006,10008,10009,10010,10018">測試2</OPTION>
<OPTION value="10004,10005,10006,10008,10009,10010,10018">測試3</OPTION>
<OPTION value="10004,10006,10008">測試4</OPTION>
<OPTION value="10004,10010,10018">測試5</OPTION>
</select>
</BODY>
</HTML>
具體思路為:先初始一個最小數(shù)組為A數(shù)組,元素個數(shù)最小的也是數(shù)組A的長度.然后再迭代各個數(shù)組,取得這幾個數(shù)組長度最短的為最小長度,同時得到長度最短數(shù)組。然后,迭代最小數(shù)組與各個數(shù)組,開始比較元素相等,使用計數(shù)器來判斷是否該元素在各個數(shù)組中都存在即為交集元素.
思路比較簡單,但是可以實(shí)現(xiàn)多數(shù)組取得交集,代碼如下:
復(fù)制代碼 代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<script>
function getValues(obj){
var values = "";
var l = obj.options.length;
for (var i=0; i<l; i++) {
if (i != (l-1)) {
values += obj.options(i).value + "_";
}
else {
values += obj.options(i).value;
}
}
return values;
}
function _test() {
var ids = getValues(document.all.aa);
var aa = _getIntersection(ids);
}
function _getIntersection(src) {
var tAry = src.split("_");
//最小數(shù)組
var minAry = null;
var min = tAry[0].split(",").length; //初始化第一個為長度最小的數(shù)組
minAry = tAry[0].split(",");
for (var i = 1, len = tAry.length; i<len; i++) {
var temp = tAry[i].split(",");
if (temp.length < min) {
min = temp.length;
minAry = temp;
}
}
alert("最小數(shù)組:"+minAry);
var ret = '';
for (var i = 0, len = minAry.length; i<len; i++) {
var srcNum = parseInt(minAry[i]);
var counter = 0;
for (var j = 0, ll = tAry.length; j<ll; j++) {
var tt = tAry[j].split(",");
for (var k = 0, l = tt.length; k<l; k++) {
var tarNum = parseInt(tt[k]);
if (srcNum == tarNum) {
counter ++;
}
}
}
if (counter == tAry.length) {
ret += srcNum + ",";
}
}
ret = strSlice(ret, ',');
alert("交集是:" + ret);
}
//去掉結(jié)尾分隔符
function strSlice(str, split){
if ((str!=null && str!="") && (split!=' '))
return ((str.charAt(str.length-1) == split) ? str.substring(0, str.length-1) : str);
else
return str;
}
</script>
</HEAD>
<BODY>
<button onclick="javascript:_test();">測試</button>
<select name="aa" id="aa" size="6" multiple>
<OPTION value="10004,10005,10008,10009,10010,10018">測試1</OPTION>
<OPTION value="10004,10005,10006,10008,10009,10010,10018">測試2</OPTION>
<OPTION value="10004,10005,10006,10008,10009,10010,10018">測試3</OPTION>
<OPTION value="10004,10006,10008">測試4</OPTION>
<OPTION value="10004,10010,10018">測試5</OPTION>
</select>
</BODY>
</HTML>
相關(guān)文章
elementui?日歷組件el-calendar使用總結(jié)
這篇文章主要介紹了elementui?日歷組件el-calendar使用總結(jié),引用dayjs處理日期,結(jié)合el-calendar完美實(shí)現(xiàn),需要的朋友可以參考下2024-07-07
通過JAVAScript實(shí)現(xiàn)頁面自適應(yīng)
通過JAVAScript實(shí)現(xiàn)頁面自適應(yīng)...2007-01-01
JS腳本根據(jù)手機(jī)瀏覽器類型跳轉(zhuǎn)WAP手機(jī)網(wǎng)站(兩種方式)
隨著移動互聯(lián)網(wǎng)的不斷普及,企業(yè)的網(wǎng)絡(luò)宣傳不僅只局限在PC端,還要在移動端發(fā)展。我們在自己的網(wǎng)站做了WAP手機(jī)完整之后,如果有用戶通過手機(jī)訪問我們的企業(yè)頂級域名網(wǎng)站,就要判斷跳轉(zhuǎn)到專為的WAP網(wǎng)站,下面小編給大家整理有關(guān)手機(jī)瀏覽器跳轉(zhuǎn)WAP手機(jī)網(wǎng)站的相關(guān)內(nèi)容2015-08-08
微信小程序?qū)崿F(xiàn)自定義modal彈窗封裝的方法
這篇文章主要介紹了小程序自定義modal彈窗封裝實(shí)現(xiàn)方法,本文通過實(shí)例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-06-06
Javascript如何判斷數(shù)據(jù)類型和數(shù)組類型
這篇文章主要介紹Javascript如何判斷數(shù)據(jù)類型和數(shù)組類型,通俗易懂,需要的朋友可以參考下。2016-06-06
js實(shí)現(xiàn)鼠標(biāo)拖拽多選功能示例
本篇文章主要介紹了js實(shí)現(xiàn)鼠標(biāo)拖拽多選功能示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08
JS獲取浮動(float)元素的style.left值為空的快速解決辦法
這篇文章主要介紹了JS獲取浮動(float)元素的style.left值為空的快速解決辦法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02

